springboot-1.5.x 拦截器配置和不起作用原因

本文介绍如何在SpringBoot中定义和配置拦截器,包括创建拦截器类和配置类的方法,同时分析了拦截器不生效的常见原因及解决策略。
1. 定义拦截器类
public class ReSubmitInterceptor extends HandlerInterceptorAdapter {

        

/**
 * 进入controller前判断是否要验证重复提交
 */
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
      throws Exception {

     }

 

}

 

2. 编写配置类
@Configuration public class ResourceHandlerConfig extends WebMvcConfigurationSupport {

       

/**
 * 注册 拦截器
 */
@Override
public void addInterceptors(InterceptorRegistry registry) {
   registry.addInterceptor(new ReSubmitInterceptor())
         .addPathPatterns("/**").excludePathPatterns("/error/page/**");
}

}

 

 

3. 可能造成拦截器不生效的原因:

  以前遇到要使用springboot拦截器却始终未生效的状况,查了网上的博客,大抵都是@Component,@Configuration注解未加,或是使用@ComponentScan增加包扫描,但是尝试后都没有生效,最后才发现是因为之前为了解决跨域问题配置类继承了WebMvcConfigurationSupport,并重写了里面的方法。之后的拦截器配置类同样继承了这个这个类并重写方法,它只会生效前一个配置类,后一个配置类不会生效,所以解决方法就是在一个配置类重写这两个方法就行了,不要分成两个配置类写。

### 可能的原因分析 如果Spring Boot 3.x中的拦截器未按照预期起作用,可能有多种原因造成此现象。通常情况下,确保拦截器正常工作的几个关键点包括: - **确认实现方式**:在Spring Boot 3.x中配置拦截器的方式与之前版本基本一致,仍然推荐通过`implements WebMvcConfigurer`的方式来定义自定义的拦截逻辑[^1]。 - **注册路径模式匹配**:当向应用上下文中添加新的拦截器实例时,需注意指定要被该拦截器处理的具体URL路径模式以及排除不需要拦截的特定路径。例如,在某些场景下可能会希望放行静态资源文件访问而不触发任何业务层面的安全校验逻辑[^3]。 - **测试验证过程**:为了排查当前设置是否存在错误,建议先简化问题域——创建最基础的功能模块用于初步调试;之后逐步引入复杂度更高的组件直至定位到具体影响因素为止。对于简单的功能测试而言,编写一个带有`@RestController`注解的控制器类并配合相应的API端点能够有效帮助理解整个流程的工作机制[^2]。 下面给出一段基于上述原则调整后的代码片段作为参考案例: ```java import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class MyWebConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { // 添加全局生效的拦截器,并指明哪些路径应该忽略掉 registry.addInterceptor(new MyCustomInterceptor()) .addPathPatterns("/**")// 对所有请求都进行拦截 .excludePathPatterns("/login", "/register", "/static/**"); } } ``` 此外还需关注项目依赖项及其版本兼容性情况,因为第三方库更新也可能间接引起此类异常行为的发生。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值