BUG记录: 拦截器 handler instanceof HandlerMethod 一直为false ( 原因导错了jar包 )

该博客讲述了在Spring MVC框架中,如何利用HandlerMethod进行请求处理的预检查。主要讨论了为何handler instanceof HandlerMethod始终返回false的问题,原来是由于导入错误的包导致。文章还介绍了如何实现基于Http请求头的token提取,以及使用JwtIgnore注解进行鉴权豁免的方法。同时,对于无token的情况抛出了异常,并在验证成功后将token存储到本地缓存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

handler instanceof HandlerMethod 一直为false 是因为导错了包
应该导入:

import org.springframework.web.method.HandlerMethod;

在这里插入图片描述

   @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 从http请求头中取出token
        final String token = request.getHeader(JwtUtil.AUTH_HEADER_KEY);
        //如果不是映射到方法,直接通过
        if(!(handler instanceof HandlerMethod)){
            return true;
        }
        //如果是方法探测,直接通过
        if (HttpMethod.OPTIONS.equals(request.getMethod())) {
            response.setStatus(HttpServletResponse.SC_OK);
            return true;
        }
        //如果方法有JwtIgnore注解,直接通过
        HandlerMethod handlerMethod = (HandlerMethod) handler;
        Method method=handlerMethod.getMethod();
        if (method.isAnnotationPresent(JwtIgnore.class)) {
            JwtIgnore jwtIgnore = method.getAnnotation(JwtIgnore.class);
            if(jwtIgnore.value()){
                return true;
            }
        }
//        LocalAssert.isStringEmpty(token, "token为空,鉴权失败!");
        if (StringUtils.isEmpty(token)){
            throw new BaseException("token为空,鉴权失败!");
        }
        //验证,并获取token内部信息
        Claims claims = JwtUtil.parseJWT(token);
        String userToken = claims.getSubject();
        //将token放入本地缓存
        WebContextUtil.setUserToken(userToken);
        return true;
    }
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值