自定义注解跳过Token验证(二)

自定义注解跳过Token验证

JWT+token+redis实现登录逻辑中通过配置webconfig对登录接口进行放行,现通过给对应接口添加注解的方式使其不用经过token验证

  1. PassToken.java 自定义注解
@Target({ElementType.METHOD,ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface PassToken {
    
}
  1. AuthenticationInterceptor.java 修改拦截器preHandle方法
  @Override
    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse,Object object)  {

        //判断方法是否有PassToken注解 如果有则放行
        if(object instanceof HandlerMethod) {
            HandlerMethod handlerMethod = (HandlerMethod) object;
            Method method = handlerMethod.getMethod();
            if (method.isAnnotationPresent(PassToken.class)) {
                    return true;
            }
        }
        //获取请求头信息
        String token = httpServletRequest.getHeader("token");
        if (token == null) {
            return false;
        }
        String username;
        try {
            username = JWT.decode(token).getAudience().get(0);
        } catch (Exception j) {
           return false;
        }

        // 验证 token
        JWTVerifier jwtVerifier = JWT.require(Algorithm.HMAC256(userService.getPassword(username))).build();
        try {
            jwtVerifier.verify(token);
        } catch (JWTVerificationException e) {
            return false;
        }
        return true;
    }

  1. TestVontroller.java 在测试方法上添加PassToken注解
@RestController
@RequestMapping("/test")
public class TestController {

    @GetMapping
    @PassToken
    public void test(){
        System.out.println("hello world");
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值