- 作用范围:过滤器基于Servlet规范,作用于更广泛的层面,不仅限于Spring MVC,它可以拦截进入Web应用的所有请求,包括静态资源请求。过滤器可以对请求和响应的内容进行预处理和后处理。
- 实现方式:过滤器需要实现javax.servlet.Filter接口,并在web.xml中配置,或使用Spring Boot的@WebFilter注解进行配置。
- 执行时机:过滤器的执行时机更早,它在请求进入Servlet之前和响应离开Servlet之后执行,可以用来做字符编码转换、安全验证、压缩响应内容等。
- 依赖性:过滤器依赖于Servlet容器,是Java EE标准的一部分,无需依赖Spring框架。
SpringBoot中拦截器与过滤器区别:
拦截器更面向业务逻辑,与Spring框架集成紧密,而过滤器则更加通用,适用于更底层的网络请求处理。
- 拦截器:通常用于处理业务逻辑相关的拦截,如权限检查、日志记录、事务管理等,更适合需要访问Spring容器中Bean的场景。
- 过滤器:适用于更底层的处理,如处理跨站脚本攻击(XSS)、敏感词过滤、请求与响应内容的修改等,尤其是那些不特定于某个框架的通用处理逻辑。
拦截器构建文章:SpringBoot中HandlerInterceptor拦截器的构建详细教程-CSDN博客
目录
Spring Boot项目构建过滤器
1、新建一个springboot项目
2、创建过滤器类
3、注册过滤器
方法一:使用@Bean
方法二:使用@WebServletComponentScan
4、创建controller类
5、启动Spring Boot应用
Spring Boot项目构建过滤器
1、新建一个springboot项目
项目完成后的结构:
pom文件:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.softeem</groupId><artifactId>springboot</artifactId><version>0.0.1-SNAPSHOT</version><name>springboot</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><spring-boot.version>2.6.13</spring-boot.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>${spring-boot.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>3.8.1</version><configuration><source>1.8</source><target>1.8</target><encoding>UTF-8</encoding></configuration></plugin><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>${spring-boot.version}</version><configuration><mainClass>com.softeem.springboot.SpringbootApplication</mainClass><skip>true</skip></configuration><executions><execution><id>repackage</id><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build></project>
2、创建过滤器类
//@WebFilter(urlPatterns = "/user/*") //看注册过滤器方法而定,如果采用@WebServletComponentScan 就需要这个注解
public class MyFilter implements Filter {@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {System.out.println("--------------您已进入过滤器------------");filterChain.doFilter(servletRequest, servletResponse);}
}
详解:
- @WebFilter(urlPatterns = "/user/*"):这个注解用来标记该类是一个过滤器,并且指定了该过滤器需要拦截的URL模式。(此处表示所有以/user/开头的请求路径都会被此过滤器处理)
- 实现javax.servlet.Filter接口的核心方法doFilter,这个方法会在每次请求匹配到该过滤器的URL模式时被调用。
- filterChain.doFilter(servletRequest, servletResponse); 这行代码是调用过滤链中的下一个过滤器或最终的目标资源。
3、注册过滤器
方法一:使用@Bean
在Sprin Boot的配置类中,可以通过@Bean注解将过滤器类注册为一个Bean,并使用FilterRegistrationBean来配置过滤器的详细信息。
@Configuration
public class FilterConfig {@Beanpublic FilterRegistrationBean myFilterRegistrationBean(){//注册过滤器FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new MyFilter());//添加过滤路径filterRegistrationBean.addUrlPatterns("/user/*");return filterRegistrationBean;}
}
方法二:使用@WebServletComponentScan
不需要配置类,但需要在上文创建的过滤器类添加注解@WebFilter(urlPatterns = "/user/*")
在主启动类添加注解@ServletComponentScan
4、创建controller类
@RestController
public class UserController {@RequestMapping("/user/detail")public String userDetail() {return "/user/detail";}@RequestMapping("/center")public String center() {return "center";}
}
5、启动Spring Boot应用
访问/uer/路径
控制台显示