Java的Filter与Spring的Interceptor的比较


一、技术规范与框架依赖

维度 Filter Interceptor
所属规范 Servlet 规范(Java EE 标准组件) Spring MVC 框架组件(非 Java EE 标准)
框架依赖 不依赖 Spring,仅需 Servlet 容器(如 Tomcat) 依赖 Spring MVC 框架,需 Spring 容器管理
应用层级 Servlet 容器层(处理 HTTP 请求的底层入口) Spring MVC 层(位于 DispatcherServlet 处理流程中)

二、作用范围与拦截能力

维度 Filter Interceptor
拦截范围 拦截所有 HTTP 请求(包括静态资源、非 Spring 管理的请求) 仅拦截 Spring MVC 请求(无法拦截静态资源或非 Spring Controller 的请求)
数据访问 仅操作 ServletRequest/ServletResponse 可访问 HandlerMethodModelAndView 等 Spring 上下文对象
典型场景 全局字符编码、跨域处理、安全防护(XSS/SQL 注入) 业务级权限校验、日志记录、请求参数预处理

三、生命周期与执行顺序

维度 Filter Interceptor
生命周期 由 Servlet 容器管理,随 Web 应用启动初始化,销毁于应用关闭 由 Spring 容器管理,依赖 Spring 上下文生命周期
执行顺序 在 DispatcherServlet 处理前执行,按 web.xml@WebFilter 声明顺序 在 DispatcherServlet 处理后执行,按 Spring 注册顺序(可通过 @Order 调整)
方法触发时机 init()doFilter()destroy() preHandle()postHandle()afterCompletion()

四、功能特性与扩展能力

维度 Filter Interceptor
依赖注入 默认不支持,需通过 FilterRegistrationBean 或手动获取 Spring Bean 天然支持 Spring 依赖注入(如 @Autowired
异常处理 抛出异常无法被 Spring 全局异常处理器捕获(需自行处理或重定向) 可通过 @ControllerAdvice 统一处理异常
扩展灵活性 功能通用性强,适合底层操作(如请求/响应流修改) 与 Spring 生态深度集成,支持动态配置和业务逻辑扩展

五、配置方式与代码示例

  1. Filter 配置
    • 原生 Servlet 配置(web.xml):
xml 复制代码
<filter>
  <filter-name>EncodingFilter</filter-name>
  <filter-class>com.example.EncodingFilter</filter-class>
</filter>
<filter-mapping>
  <filter-name>EncodingFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

• Spring Boot 配置(FilterRegistrationBean):

java 复制代码
@Bean
public FilterRegistrationBean<EncodingFilter> encodingFilter() {
    FilterRegistrationBean<EncodingFilter> bean = new FilterRegistrationBean<>();
    bean.setFilter(new EncodingFilter());
    bean.addUrlPatterns("/*");
    return bean;
}
  1. Interceptor 配置
    • Spring MVC 配置(WebMvcConfigurer):
java 复制代码
@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new AuthInterceptor())
                .addPathPatterns("/api/**")
                .excludePathPatterns("/api/login");
    }
}

六、选型建议与最佳实践

场景 推荐技术 理由
全局请求处理(如字符编码) Filter 拦截所有请求,不依赖 Spring,性能开销低
业务逻辑拦截(如权限校验) Interceptor 可访问 Spring 上下文,支持细粒度路径控制
静态资源处理(如图片缓存) Filter 能拦截静态资源,适合缓存控制或防盗链
响应数据后处理(如日志记录) Interceptor 利用 postHandle 修改响应内容,结合 ModelAndView

总结

• Filter 核心优势:底层通用性强、拦截范围广、适合与 Servlet API 直接交互的场景。

• Interceptor 核心优势:与 Spring 生态无缝集成、支持精细化业务拦截、可操作 Spring 上下文。

根据需求选择,两者亦可组合使用(如 Filter 处理编码 → Interceptor 处理权限)。


spring中的Interceptor使用说明
java中的Filter使用详解

相关推荐
武子康1 分钟前
Java-82 深入浅出 MySQL 内部架构:服务层、存储引擎与文件系统全覆盖
java·开发语言·数据库·学习·mysql·spring·微服务
Rancemy1 分钟前
rabbitmq 03
java·分布式·rabbitmq
惜.己29 分钟前
pytest中使用skip跳过某个函数
开发语言·python·测试工具·pytest
姜暮儿31 分钟前
C++ 性能优化
开发语言·c++
啊呦.超能力1 小时前
QT开发---多线程编程
开发语言·qt
铭哥的编程日记2 小时前
《从C风格到C++风格:内存管理的进化之路》
开发语言·c++
Dcs2 小时前
“SQL注入即服务”:一个10年历史系统的奇幻演变
java
秃了也弱了。2 小时前
reflections:Java非常好用的反射工具包
java·开发语言
Amagi.3 小时前
Java设计模式-代理模式
java·代理模式
Joker—H3 小时前
【Java】Reflection反射(代理模式)
java·开发语言·经验分享·代理模式·idea