微服务项目->在线oj系统(Java-Spring)----7.0
延迟token时间
由于我们延迟token的时机在于登录获得token之后,在调用Controller之前,那我们可以把延长的时机订到拦截器中,我们可能会想着可以单独弄一个过滤器,但是这样一方面以后可能添加其他过滤器导致问题,也会增加代码直接耦合度,所以我们这里选择使用过滤器
实现拦截器
@Component
public class TokenInterceptor implements HandlerInterceptor {@Autowiredprivate TokenService tokenService;@Value("${jwt.secret}")private String secret; //从哪个服务的配置文件中读取,取决于这个bean对象交给了哪个服务的spring容器进行管理。@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {String token = getToken(request); //请求头中获取tokentokenService.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 {@Autowiredprivate TokenInterceptor tokenInterceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(tokenInterceptor).excludePathPatterns("/**/login").addPathPatterns("/**");}
}