拦截器实现JWT验证

发布时间 2023-09-20 23:41:16作者: 小臣敲键盘

拦截器实现JWT验证

要在每个请求发送后验证JWT Token的有效性,可以使用Spring中的拦截器(interceptor)来实现。拦截器可以在请求到达控制器之前对请求进行预处理,包括验证JWT Token的有效性。以下是一个简单的示例:

首先,创建一个拦截器类 JwtInterceptor,用于验证JWT Token的有效性:

//Jwt验证拦截
@Component
public class JwtInterceptor implements HandlerInterceptor {

    private final JwtUtils jwtUtils;

    public JwtInterceptor(JwtUtils jwtUtils) {
        this.jwtUtils = jwtUtils;
    }

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 从请求头中获取Token
        String token = request.getHeader("Authorization");

        if (token != null && token.startsWith("Bearer ")) {
            // 去除Token前缀
            String jwtToken = token.substring(7);


            // 验证Token的有效性,具体验证方法可自定义
            Claims claims = jwtUtils.parseJwt(jwtToken);
            Date expirationDate = claims.getExpiration();
            if (claims.get("userid") != null && expirationDate != null && expirationDate.after(new Date()))
                return true; // 验证通过,继续处理请求
            else
                return false;
        }
        else
            return false;
    }
}

接下来,配置该拦截器类,并将其添加到Spring的拦截器链中。创建一个配置类 WebMvcConfig

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {

    private final JwtInterceptor jwtInterceptor;

    public WebMvcConfig(JwtInterceptor jwtInterceptor) {
        this.jwtInterceptor = jwtInterceptor;
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(jwtInterceptor)
                .excludePathPatterns("/api/Signin")
                .excludePathPatterns("/api/Signup"); // 声明放行的路径,不进行Token验证

        // 可以根据需求添加更多拦截器
        // registry.addInterceptor(anotherInterceptor);
    }
}