springboot拦截器excludePathPatterns方法不生效的坑与解决方法

一、前言

最近在springboot项目里需要配置个拦截器白名单,用excludePathPatterns方法配置些url,让拦截器不拦截这些url;

本来这是个很简单的东西,但是配置完毕后就是没有生效;

在此记录下这个坑的解决方法。

二、问题

1.例如,想让以下url不被拦截器拦截:
http://localhost:8080/survey-project/download/special

2.拦截器配置代码如下:

//这是拦截器配置类
@Configuration
public class InterceptorConfig extends WebMvcConfigureAdapter {

//这是一个自己写的拦截器类
@Autowired
private MyInterceptor myInterceptor;

@Override
public void addInterceptors(InterceptorRegistry registry){
  registry.addInterceptor(myInterceptor)
  //这里配置要拦截的路径
  .addPathPatterns("/**")
  //这里配置不要拦截的路径
  .excludePathPatterns("/**/login","/**/register",
  //这里配置不拦截上方的url
  "/survey-project/download/**");
}

}

3.看起来没有问题,但是当访问上方url的时候,还是会被拦截器拦截,就很坑。

三、解决方法

1.通过排查发现,原来,在application.yml中,是这样配置的:

server:
  port: 8080
  context-path: /survey-project

2.所以,还是拦截器的url配置错了,想不拦截的话,需要这样配置:

registry.addInterceptor(myInterceptor)
  .addPathPatterns("/**")
  .excludePathPatterns("/**/login","/**/register",
  //这里配置不拦截上方的url
  "/download/**");

3.这样,访问这个url,才能不被拦截器拦截:
http://localhost:8080/survey-project/download/special

四、总结

1.配置拦截器时,如果excludePathPatterns没有生效,可能是url配置有问题。
2.可以检查下application.ymlcontext-path,或者其它类似的地方,配置拦截器的url不应该包含这些路径,只要从Controller的路径开始配置即可。

### 解析 Spring Boot 拦截器白名单不生效解决方案 #### 1. 配置路径模式匹配规则 确保 `excludePathPatterns` 属性配置无误。此属性用于定义不需要被拦截的URL路径列表,支持Ant风格通配符语法[^3]。 ```java @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyCustomInterceptor()) .addPathPatterns("/**") // 所有请求都被拦截 .excludePathPatterns("/login", "/register", "/static/**"); // 白名单路径 } ``` #### 2. 启动类位置校验 确认启动类位于合适的位置以便能够扫描到自定义配置类。当Web配置类(如实现了`WebMvcConfigurer`接口并重写了`addInterceptors()`方法的类)不在主应用程序类所在的包或其子包内时,可能会导致组件未被正确加载[^2]。 #### 3. 资源映射处理 对于静态资源文件夹下的资源访问应予以豁免,通常建议将所有前端所需的静态资源统一放置于特定目录下,并通过单一表达式来排除这些资源的拦截需求。 #### 4. 日志调试辅助诊断 启用日志记录可以帮助追踪实际发生的过滤过程,便于发现潜在问题所在。可以在application.properties中增加如下配置项开启debug级别日志输出: ```properties logging.level.org.springframework.web=DEBUG ``` 这有助于观察每次HTTP请求经过哪些处理器以及它们是如何工作的。 #### 5. 测试验证机制健全性 构建单元测试案例模拟不同场景下的请求行为,特别是针对那些应该绕过拦截逻辑的情况做重点检验。利用MockMvc工具可以方便地完成这项工作。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

追逐梦想永不停

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值