微服务项目->在线oj系统(Java-Spring)----7.0

延迟token时间

由于我们延迟token的时机在于登录获得token之后,在调用Controller之前,那我们可以把延长的时机订到拦截器中,我们可能会想着可以单独弄一个过滤器,但是这样一方面以后可能添加其他过滤器导致问题,也会增加代码直接耦合度,所以我们这里选择使用过滤器

实现拦截器

复制代码
@Component
public class TokenInterceptor implements HandlerInterceptor {

    @Autowired
    private TokenService tokenService;

    @Value("${jwt.secret}")
    private String secret;  //从哪个服务的配置文件中读取,取决于这个bean对象交给了哪个服务的spring容器进行管理。

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String token = getToken(request);  //请求头中获取token
        tokenService.extendToken(token,secret);
        return true;
    }
    private String getToken(HttpServletRequest request) {
        String token = request.getHeader(HttpConstants.AUTHENTICATION);
        if (StrUtil.isNotEmpty(token) && token.startsWith(HttpConstants.PREFIX)) {
            token = token.replaceFirst(HttpConstants.PREFIX, "");
        }
        return token;
    }
}

这里的secret采用依赖注入的方式,因为我们这里是为了让哪个服务被拦截的时候,就从哪个服务的nacos中读取

注册拦截器

复制代码
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {

    @Autowired
    private TokenInterceptor tokenInterceptor;

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(tokenInterceptor)
                .excludePathPatterns("/**/login")
                .addPathPatterns("/**");
    }
}
相关推荐
一起养小猫2 分钟前
LeetCode100天Day2-验证回文串与接雨水
java·leetcode
清晓粼溪6 分钟前
Java登录认证解决方案
java·开发语言
液态不合群12 分钟前
查找算法详解
java·数据结构·算法
雨中飘荡的记忆15 分钟前
观察者模式:从理论到生产实践
java·设计模式
北城以北888816 分钟前
SpringBoot--Redis基础知识
java·spring boot·redis·后端·intellij-idea
⑩-21 分钟前
SpringCloud-Feign客户端实战
后端·spring·spring cloud
wniuniu_23 分钟前
ceph中的rbd的稀疏写入
java·服务器·数据库
2201_7578308731 分钟前
条件分页查询
java·开发语言
重生之我是Java开发战士35 分钟前
【数据结构】Java对象的比较
java·jvm·数据结构
橘子1342 分钟前
Linux线程——一些概念(七)
java·redis·缓存