百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

炸场!Spring Boot 9 大内置过滤器实战手册:从坑到神

off999 2025-09-21 21:18 14 浏览 0 评论

炸场!Spring Boot 9 大内置过滤器实战手册:从坑到神

在 Java 开发圈摸爬滚打十年,见过太多团队重复造轮子 —— 明明 Spring Boot 自带的过滤器就能解决的问题,偏偏要手写几十行代码。今天就带大家深挖 Spring Boot 内置的 9 个过滤器,从配置到排坑,全是能直接复用的实战经验。

一、先搞懂过滤器的 "生存法则"

很多人分不清过滤器 (Filter) 和拦截器 (Interceptor),其实记住三句话就够了:过滤器是 Servlet 规范的 "老炮儿",作用于所有请求包括静态资源;拦截器是 Spring 的 "后起之秀",只认 Controller 方法。过滤器像小区门卫,管你是住户还是快递员都得查;拦截器则像单元楼门禁,只拦去拜访业主的人。

在 Spring Boot 里注册过滤器有两种姿势:用 @WebFilter+@ServletComponentScan 是 "简单模式",适合快速开发;用 FilterRegistrationBean 是 "专业模式",能精确控制顺序和 URL 匹配,生产环境强烈推荐后者。记住过滤器的生命周期:init () 初始化只执行一次,doFilter () 每次请求都触发,destroy () 销毁时释放资源。

二、9 大过滤器实战拆解

1. CharacterEncodingFilter:终结中文乱码的终极方案

新手常踩的坑:页面提交的中文变成问号,排查半天发现是编码没配置对。这个过滤器就是来救场的,Spring Boot 2.x 默认启用,3.x 需要手动配置。

实战配置要注意两个关键点:

java

@Bean
public FilterRegistrationBean<CharacterEncodingFilter> encodingFilter() {
    CharacterEncodingFilter filter = new CharacterEncodingFilter();
    filter.setEncoding("UTF-8");
    filter.setForceEncoding(true); // 强制覆盖容器编码,必须设为true
    FilterRegistrationBean<CharacterEncodingFilter> bean = new FilterRegistrationBean<>(filter);
    bean.setOrder(Ordered.HIGHEST_PRECEDENCE); // 优先级要最高
    return bean;
}

曾经接手过一个项目,因为把 forceEncoding 设为 false,Tomcat 的 ISO-8859-1 编码把 UTF-8 覆盖了,导致乱码问题反复出现。记住:这个过滤器必须第一个执行,否则后面的处理都是白搭。

2. HiddenHttpMethodFilter:让表单支持 RESTful 的魔法

HTML 表单天生只认 GET 和 POST,想实现 PUT/DELETE 请求怎么办?这个过滤器能把 POST 请求 "伪装" 成其他方法,只需前端加个隐藏字段:

html

<form action="/user/1" method="post">
    <input type="hidden" name="_method" value="DELETE">
</form>

Spring Boot 3.x 需要手动开启:

yaml

spring.mvc.hiddenmethod.filter.enabled: true

注意它只对 POST 请求生效,且要和 @PathVariable 配合使用。现在前后端分离项目常用 Axios 直接发 PUT 请求,这个过滤器更多用于传统 JSP 项目。

3. FormContentFilter:PUT 请求的表单解析器

Servlet 规范有个坑:PUT 请求的表单数据不会被解析到 request.getParameter () 里。这个过滤器就是来填坑的,它会把表单数据包装成可解析的格式。

在 Spring Boot 3.x 中默认启用,无需额外配置。适合那些还在使用表单提交,但又想遵循 RESTful 规范的老项目。测试时发现,它对 multipart/form-data 类型的支持不太好,文件上传还是乖乖用 POST 吧。

4. RequestContextFilter:让请求信息随处可用

想在 Service 层获取当前请求的 IP 地址?这个过滤器能帮你实现。它通过 RequestContextHolder 把请求上下文绑定到线程,在任何地方都能拿到:

java

HttpServletRequest request = ((ServletRequestAttributes) 
    RequestContextHolder.getRequestAttributes()).getRequest();

它的升级版
OrderedRequestContextFilter 支持设置执行顺序,当需要在其他过滤器中使用请求信息时,一定要让它先执行。曾经在日志拦截器里拿不到请求信息,就是因为没控制好这个过滤器的顺序。

5. CorsFilter:跨域问题的终极解决方案

前后端分离项目必用!比 @CrossOrigin 注解更适合全局配置。复杂场景的配置示例:

java

@Bean
public CorsFilter corsFilter() {
    CorsConfiguration config = new CorsConfiguration();
    config.setAllowedOrigins(Arrays.asList("https://admin.example.com"));
    config.setAllowedMethods(Arrays.asList("GET", "POST", "PUT", "DELETE"));
    config.setAllowedHeaders(Arrays.asList("Authorization", "Content-Type"));
    config.setAllowCredentials(true); // 允许带cookie
    config.setMaxAge(3600L); // 预检请求缓存1小时
    
    UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
    source.registerCorsConfiguration("/api/**", config);
    return new CorsFilter(source);
}

踩过的坑:allowedOrigins 设为 ""时,allowCredentials 必须为 false,否则浏览器会报错。生产环境一定要精确指定允许的源,别图省事用""。

6. ShallowEtagHeaderFilter:带宽杀手的克星

这个过滤器能生成响应内容的哈希值作为 ETag,客户端再次请求时比对 ETag,相同就返回 304,大幅减少数据传输。配置时要注意只对频繁访问且变化少的资源生效:

java

@Bean
public FilterRegistrationBean<ShallowEtagHeaderFilter> etagFilter() {
    FilterRegistrationBean<ShallowEtagHeaderFilter> bean = new FilterRegistrationBean<>();
    bean.setFilter(new ShallowEtagHeaderFilter());
    bean.addUrlPatterns("/api/reports/*", "/static/docs/*");
    return bean;
}

注意它会增加服务器开销(需要计算哈希),不适合动态内容多的接口。曾经给一个报表接口加了这个过滤器,带宽消耗降了 60%,但服务器 CPU 上升了 5%,需要权衡使用。

7. ForwardedHeaderFilter:反向代理后的 "真实面目"

应用部署在 Nginx 后面时,request.getScheme () 拿到的是 http 而不是 https?这个过滤器能解析 X-Forwarded-* 头信息,还原客户端真实的协议、IP 和端口。

Spring Boot 2.2 + 只需配置:

yaml

server.forward-headers-strategy: FRAMEWORK

在微服务架构中特别重要,不然服务间调用获取到的客户端 IP 都是 Nginx 的地址。记得让 Nginx 配置正确的转发头:

nginx

proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

8. ResourceUrlEncodingFilter:静态资源缓存的破局者

前端缓存常导致新功能上线后用户看不到更新,这个过滤器能生成带版本号的资源 URL,如 /style.css 变成 /style-8f4d7b92.css。

配合 Spring 的资源版本策略使用:

java

@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/static/**")
                .addResourceLocations("classpath:/static/")
                .resourceChain(true)
                .addResolver(new VersionResourceResolver()
                        .addContentVersionStrategy("/**"));
    }
}

这样每次资源内容变化,URL 就会变化,彻底解决缓存更新问题。

9. WelcomePageFilter:首页跳转的隐形推手

这个过滤器默默处理着首页跳转逻辑,当访问根路径时,会自动转发到 index.html。在静态资源目录放个 index.html,就能轻松实现首页功能,无需写 Controller。

如果需要自定义首页,可以通过配置覆盖:

yaml

spring.web.resources.static-locations: classpath:/public/

它的优先级低于 Controller 映射,所以如果有 @RequestMapping ("/"),会优先执行控制器方法。

三、过滤器链的调优秘籍

过滤器多了会影响性能,这几个优化技巧能让你少走弯路:

  1. 精准匹配 URL:用 addUrlPatterns ("/api/") 而不是"/",减少过滤范围。比如编码过滤器需要全局生效,但 ETag 过滤器只需要对特定接口生效。
  2. 控制执行顺序:通过 setOrder () 方法合理排序,推荐顺序:编码过滤器> 上下文过滤器 > CORS 过滤器 > 业务过滤器。曾经因为 CORS 过滤器执行太晚,导致预检请求被其他过滤器拦截,排查了整整一下午。
  3. 禁用不需要的过滤器:Spring Boot 默认启用了一些过滤器,如果用不上可以禁用,比如:

yaml

spring.mvc.formcontent.filter.enabled: false
  1. 异步处理优化:在过滤器中调用 chain.doFilter () 时,如果是异步请求,考虑用 AsyncContext 提高吞吐量。

四、避坑指南:那些年踩过的过滤器陷阱

  1. 过滤器和拦截器执行顺序混淆:过滤器在 DispatcherServlet 之前执行,拦截器在之后,所以拦截器里拿不到过滤器修改后的 request 属性是正常的。
  2. 多个过滤器修改同一属性:比如两个过滤器都想设置 response 头,后执行的会覆盖先执行的,需要注意顺序。
  3. 忘记处理 chain.doFilter ():如果在过滤器中忘记调用这个方法,请求就会被截断,这是新手最容易犯的错误。
  4. 过度使用过滤器:有些功能更适合用 AOP 实现,比如日志记录,过滤器更适合处理与 Servlet 相关的横切逻辑。

结语

Spring Boot 内置的这 9 个过滤器,每一个都解决了实际开发中的痛点问题。很多时候我们不需要从零开始写代码,而是要学会利用好框架提供的工具。记住:优秀的开发者不是写最多代码的人,而是最会用最少代码解决问题的人。

这些过滤器你用过几个?欢迎在评论区分享你的使用经验和踩坑故事,让更多人少走弯路。


感谢关注【AI码力】!

相关推荐

win10激活在哪里查看(win10激活时间在哪里看)

在Windows10中,您可以通过以下方法查看激活状态:方法1:使用“设置”应用1.点击屏幕左下角的“开始”按钮,然后点击“设置”(齿轮图标)。2.在设置窗口中,点击“系统”图标。3.在“系统...

官方win10dll文件修复工具(官方win7dll文件修复工具)

当电脑丢失dll文件时,可以采用以下几种方法进行一键修复:从回收站还原:如果是不小心误删了一些计算机文件,导致电脑出现异常的情况时,首先就可以去回收站找回dll文件,如果文件还在,就可以通过还原操作来...

qq所有历史旧版本大全(qq历史版本一览表)

有2种方法。一种是:你是QQ会员。你可以把旧版打开,聊天记录上传。然后打开新的QQ,下载。第2种是:你在硬盘上装了QQ软件,然后你就点卸载(uninst),把原来的卸了。然后按原位置覆盖,装上06版。...

电脑显示器分辨率怎么调(显示分辨率无法调整)

1、以win7为例,首先右键点击桌面,在右键菜单中直接显示了屏幕分辨率的选项,用鼠标点击一下这个选项。2、在分辨率设置选项页面中,有一个分辨率的选项,点击一下这个选项,上面默认显示的数值是你现在的屏幕...

8系统(8系统点检控制包含什么)

WIndows8系统是微软目前最新的操作系统,Moto的图形界面设计,使很多已经习惯于早期windows系统的用户难以接受,Windows8是一个向平板和桌面系统妥协的产物,存在着相当多的利弊。...

电脑软件管家(电脑软件管家在哪里找到)

电脑管家有着最大的安全云库,全新的杀毒引擎,深度清理电脑垃圾,为电脑重回巅峰状态,更有账号宝专版,10倍提升QQ防盗号能力,是很好用的。就自己而言,在电脑上用的是腾讯电脑管家这个第三方系统安全软件,管...

office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
迅雷种子搜索器(迅雷种子搜索器手机版下载)

    迅雷种子搜索方法:    1.在开始菜单栏或者到文件的安装路径文件夹中找到P2P种子搜索器。&nb...

手机怎么解压文件(苹果手机怎么解压文件)

手机解压文件方法:1、首先,在手机中找到文件管理,打开文件管理。2、打开文件管理之后找到压缩包,然后打开。3、打开安装包之后,选择需要的文件,。4、接下来找到“解压至”,点击“解压至”。5、点击之后,...

虚拟机安装centos7(虚拟机安装centos7图形界面)

安装CentOS7在虚拟机中,您可以按照以下步骤操作:1.下载CentOS7的ISO映像文件。2.打开虚拟机软件(如VMware、VirtualBox等)并创建一个新的虚拟机。3.在虚拟机创...

电脑老是重启(电脑老是重启什么原因造成的)

电脑由于工作环境积尘与空气湿度过大,经常使主板的接插件部分受潮产生氧化;特别是内存条插座、PCI扩展槽、键盘鼠标接口、LOT接口、CMOS电池压盒、ATX电源插座等。一旦它们出现接触不良现象,很容易出...

win8系统怎么重装系统(win8.1系统重装教程)

1、修改Cortana资源占用:按Windows按钮,输入regedit,打开注册表编辑器,找到以下路径:HKEY_LOCAL_MACHINE—SYSTEM—CurrentControlSet—Ser...

手机163邮箱app下载(163邮箱下载手机版官网 app)

163邮箱登录首页入口为http://mail.163.com/网易163免费邮箱--中文邮箱第一品牌.容量自动翻倍,支持50兆附件,免费开通手机号码邮箱赠送3G超大附件服务.支持各种客户端软件收发,...

win10此电脑怎么放在桌面上(wind10此电脑放桌面)
win10此电脑怎么放在桌面上(wind10此电脑放桌面)

步骤/方式1右键单击桌面空白处,点击个性化。步骤/方式2点击更改桌面图标。步骤/方式3把计算机勾选上。步骤/方式4即可把此电脑图标显示在桌面上。...

2025-11-08 14:03 off999

电脑配置怎么看在电脑上(电脑配置在电脑里怎么看)

查看电脑配置的方法有多种,以下是一些常见的方法:直接查看:在电脑桌面或操作系统中,找到“我的电脑”或“此电脑”,右键点击并选择“属性”,即可查看电脑的基本配置信息,包括CPU型号、内存大小、硬盘类型和...

取消回复欢迎 发表评论: