spring boot 拦截器HandlerInterceptor 不生效的原因排查

java 复制代码
public class UserInterceptor implements HandlerInterceptor

项目添加一个拦截器,发现未生效

1、排查拦截本身是否注入了springbean 容器

java 复制代码
@Slf4j
@Component
public class LoginInterceptor implements HandlerInterceptor {

2、排查springboot 项目扫描范围是否包含了拦截器所在目录

3、排查拦截器是否注册成功

两种注册方式相互排斥

如果同时配置一个类继承WebMvcConfigurationSupport和一个类实现

WebMvcConfigurer或者WebMvcConfigurerAdapter,就会导致只有一个生效。解决办法:将这些配置都在一个类中设置

这里全局搜索WebMvcConfigurer

和WebMvcConfigurationSuppor

发现项目中已经有了

bash 复制代码
@Configuration
public class FastJsonConfig extends WebMvcConfigurationSupport 

在这里增添

bash 复制代码
@Override
  public void addInterceptors(InterceptorRegistry registry) {

    List<String> excluded=new ArrayList<>();
    excluded.add("/pc/getUserInfoByCode");
    excluded.add("pc/login");
    registry.addInterceptor(loginInterceptor)
            .addPathPatterns("/**")
            .excludePathPatterns(excluded);
    super.addInterceptors(registry);
  }

然后打断点,发现项目启动的时候拦截器注册成功,接下来可以正常拿用户登录信息了

相关推荐
点光1 天前
使用Sentinel作为Spring Boot应用限流组件
后端
不要秃头啊1 天前
别再谈提效了:AI 时代的开发范式本质变了
前端·后端·程序员
有志1 天前
Java 项目添加慢 SQL 查询工具实践
后端
山佳的山1 天前
KingbaseES 共享锁(SHARE)与排他锁(EXCLUSIVE)详解及测试复现
后端
Leo8991 天前
rust 从零单排 之 一战到底
后端
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
鱼人1 天前
MySQL 实战入门:从“增删改查”到“高效查询”的核心指南
后端
大鹏19881 天前
告别 Session:Spring Boot 实现 JWT 无状态登录认证全攻略
后端
Java编程爱好者1 天前
从 AQS 到 ReentrantLock:搞懂同步队列与条件队列,这一篇就够了
后端
鱼人1 天前
Nginx 全能指南:从反向代理到负载均衡,一篇打通任督二脉
后端