SpringBoot拦截器、过滤器介绍和使用

1. 过滤器(Filter)简介

它依赖于servlet容器。它可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的,是用来做一些过滤操作,获取我们想要获取的数据,比如:在Javaweb中,对传入的request、response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者Controller进行业务逻辑操作。通常用的场景是:在过滤器中修改字符编码(CharacterEncodingFilter)、在过滤器中修改HttpServletRequest的一些参数(XSSFilter(自定义过滤器)),如:过滤低俗文字、危险字符等。

拦截器(Inteceptor)简介

它依赖于web框架,在SpringMVC中就是依赖于SpringMVC框架。在实现上,基于Java的反射机制,属于面向切面编程(AOP)的一种运用,就是在service或者一个方法前,调用一个方法,或者在方法后,调用一个方法,比如动态代理就是拦截器的简单实现,在调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在调用方法后打印出字符串,甚至在抛出异常的时候做业务逻辑的操作。由于拦截器是基于web框架的调用,因此可以使用Spring的依赖注入(DI)进行一些业务操作,同时一个拦截器实例在一个controller生命周期之内可以多次调用。拦截器可以对静态资源的请求进行拦截处理。

区别

过滤器(Filter):

  • 是Servlet规范的一部分,可以过滤所有类型的请求。
  • 在请求到达Servlet之前以及响应返回给客户端之前执行。
  • 可以用来设置请求的字符编码、管理会话等。
  • 通过实现javax.servlet.Filter接口来创建。

拦截器(Interceptor):

  • 是Spring MVC框架的一部分,只能拦截Spring MVC管理的请求。
  • 在处理器方法执行前后执行,可以进行预处理和后处理。
  • 可以用来进行权限检查、日志记录等。
  • 通过实现org.springframework.web.servlet.HandlerInterceptor接口来创建。

图中afterHandler应该对应重写方法的afterCompletion

拦截器使用-拦截swagger

在springboot框架中一般是使用拦截器来处理一些请求。其实拦截器和过滤器能够实现的功能差不多,因为拦截器是springboot框架中集成的,用起来也比较的方便,所以经常使用拦截器来处理请求。

最近遇到一个需求,就是在生产环境中完全禁用swagger的api文档,目前通过配置文件更改配置那文件状态的方式都不能够完全禁用swagger的状态,查阅资料发现拦截器能够比较好的实现需求。

拦截器使用的步骤::

1.创建拦截器

- 实现HandlerInterceptor接口或继承HandlerInterceptorAdapter类。

- 实现拦截器的方法:通常需要实现preHandlepostHandleafterCompletion方法。

2.注册拦截器

- 将拦截器注册到Spring MVC的拦截器链中。

import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
* Swagger拦截器
*@author 
*@Date 
*/
@Component
public class SwaggerInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        response.setStatus(HttpServletResponse.SC_NOT_FOUND);
        return false;
    }
}
@Configuration
public class WebConfig implements WebMvcConfigurer{

        @Value("${yudao.swagger.enabled}")
        Boolean swaggerEnabled;

        @Resource
        SwaggerInterceptor swaggerInterceptor;

        @Override
        public void addInterceptors(InterceptorRegistry registry){
                if(!swaggerEnabled) {
                   //注册⾃定义拦截器对象
                   registry.addInterceptor(swaggerIntercepter)
                      .addPathPatterns("/webjars/**")
                      .addPathPatterns("/doc.html")
                      .addPathPatterns("/v3/api-docs/**");//设置拦截器拦截的请求路径( /** 表示拦截所有请求)
                }
        }
}

### Spring Boot 拦截器过滤器的用法及区别 #### 一、概念介绍 - **拦截器(Interceptor)** 是一种基于 Java 的反射机制,在 AOP 编程中的体现之一。它主要用于拦截用户的请求并对其进行预处理后处理操作[^1]。 - **过滤器(Filter)** 则是由 Servlet 容器提供的一种技术,能够对所有的 HTTP 请求响应进行拦截,并对其内容或头信息进行修改[^5]。 #### 二、核心区别 | 特性 | 拦截器(Interceptor) | 过滤器(Filter) | |---------------------|---------------------------------------------|------------------------------------------| | **触发时机** | 只能拦截 Controller 处理的请求 | 能够拦截所有经过容器的请求 | | **依赖关系** | 需要依赖于 Spring MVC | 不依赖任何框架,属于 Servlet API | | **访问上下文** | 可以获取到更多的 Spring 上下文中对象 | 主要是针对 HttpServletRequest HttpServletResponse 对象的操作 | | **灵活性** | 更加灵活,适合复杂的业务逻辑 | 较为简单,适用于简单的请求/响应处理 | 上述差异决定了它们在实际开发中的不同用途[^2]。 #### 三、使用场景 ##### 1. 拦截器的典型应用 - 用户权限校验:通过 `preHandle` 方法判断当前用户是否有权访问目标资源[^4]。 - 日志记录:记录请求参数、返回数据等信息以便后续分析。 - 数据转换:统一处理入参或者出参的数据格式。 ##### 2. 过滤器的典型应用 - 字符编码设置:解决中文乱码问题。 - XSS 攻击防护:过滤掉恶意脚本注入的内容。 - 性能监控:统计接口调用耗时情况。 #### 四、实现步骤 以下是两种组件的具体创建与配置方式: ##### (1)拦截器的创建与配置 ```java // 创建自定义拦截器类 public class AuthInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String token = request.getHeader("Authorization"); if (token != null && validateToken(token)) { // 假设有一个验证方法 return true; } response.setStatus(HttpServletResponse.SC_UNAUTHORIZED); return false; // 如果未通过认证,则阻止继续执行 } private boolean validateToken(String token){ // 实际验证逻辑省略... return !token.isEmpty(); } } ``` 接着注册此拦截器至全局配置中: ```java @Configuration public class WebConfig implements WebMvcConfigurer { @Bean public AuthInterceptor authInterceptor(){ return new AuthInterceptor(); } @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(authInterceptor()) .addPathPatterns("/api/**") // 应用路径模式匹配规则 .excludePathPatterns("/api/login"); // 排除某些不需要拦截的 URL } } ``` ##### (2)过滤器的创建与配置 编写一个标准的 Filter 类型 Bean 并将其加入到应用程序生命周期里去工作: ```java @Component public class EncodingFilter extends OncePerRequestFilter { @Override protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); request.setCharacterEncoding("UTF-8"); filterChain.doFilter(request,response); // 继续传递给下一个环节 } } ``` 以上代码片段展示了如何利用过滤器完成字符集调整的任务[^3]。 #### 五、执行顺序与流程 当客户端发起一次完整的 HTTP 请求到达服务端之后,整个过程会按照如下次序依次经历各个阶段: 1. 先由外部最外层的 Filters 开始逐级向下运行; 2. 当进入 DispatcherServlet 后再交予内部 Interceptors 来接管控制流; 3. 最终抵达具体的 Controllers 层面完成真正的业务计算部分后再原路返回向上走一遍相同的路径直到最后形成最终应答消息发送回前端浏览器显示出来为止。 ![执行顺序](https://example.com/spring-boot-filter-interceptor-flow.png) #### 六、常见问题与解决方案 Q: 如何让我的过滤器优先于其他第三方库自带的那个生效? A: 修改 bean definition order 或者直接指定 Order 注解数值即可达成目的。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值