延迟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("/**");
}
}