springboot拦截器 跳过_BUG记录:Springboot2.x拦截器配置不无生效

/***@author: Gabriel

* @date: 2020/2/5 13:45

* @description 登录认证拦截*/@Slf4j

@Componentpublic class AuthenticationInterceptor implementsHandlerInterceptor {

@Autowired

IUserService userService;/*** 前置处理-方法执行前执行

*@paramrequest

*@paramresponse

*@paramhandler

*@return*@throwsException*/@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throwsException {

String token= request.getHeader("token");//如果不是映射到方法就放行

if (!(handler instanceofHandlerMethod)) {return true;

}

HandlerMethod handlerMethod=(HandlerMethod) handler;//获取方法及其相关注解//检查是否有不需要登录的注解,有则跳过认证

Method method =handlerMethod.getMethod();if (method.isAnnotationPresent(NoRequiredLoginToken.class)) {

NoRequiredLoginToken noRequiredLoginToken= method.getAnnotation(NoRequiredLoginToken.class);if(noRequiredLoginToken.required()) {return true;

}

}//检查有没有需要用户权限的注解

if (method.isAnnotationPresent(RequiredLoginToken.class)) {

RequiredLoginToken requiredLoginToken= method.getAnnotation(RequiredLoginToken.class);if(requiredLoginToken.required()) {//执行认证

if(StringUtils.isBlank(token)) {throw newBusinessException(ResultCode.NO_LOGIN);

}//获取token中的userId

String userId;try{

userId=JWT.decode(token).getAudience().get(0);

}catch(JWTDecodeException e) {throw newBusinessException(ResultCode.NO_LOGIN);

}

User user=userService.getById(userId);if(ObjectUtil.isNull(user)) {//TODO 用户不存在,请重新登录,这里需要优化异常类的构造方法

throw newBusinessException(ResultCode.NO_LOGIN);

}

JWTVerifier jwtVerifier=JWT.require(Algorithm.HMAC256(user.getPassword())).build();try{

jwtVerifier.verify(token);

}catch(JWTVerificationException e) {//TODO 校验失败,token有误

throw newBusinessException(ResultCode.NO_LOGIN);

}return true;

}

}//未加注解的方法直接放行-默认是不需要校验的

return true;

}/*** 后置处理-方法执行后执行

*@paramrequest

*@paramresponse

*@paramhandler

*@parammodelAndView

*@throwsException*/@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throwsException {

}/*** 最终处理-控制器执行完成后执行

*@paramrequest

*@paramresponse

*@paramhandler

*@paramex

*@throwsException*/@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throwsException {

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值