【SpringBoot | 过滤器/拦截器/AOP/控制器】的区别

博客主要探讨了Filter、Interceptor、Aspect的设计及区别。分析了三者各自的不足,如Filter无法获取Controller方法信息等。还阐述了拦截器和过滤器在实现原理、使用范围、拦截请求范围等方面的不同,以及它们的执行顺序,此外还提及了ThreadLocal。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Filter、Interceptor、Aspect的设计及区别

【Spring】Filter、Interceptor、Aspect的设计及区别
在这里插入图片描述

Filter的不足

只拥有ServletRequest 和ServletResponse 对象,无法获取Controller相关的方法信息

Interceptor 的不足

无法获取请求参数拼装后的结果,@RequestBody 反序列化成的参数将不会出现在拦截器里。

Aspect 的不足

获取原生的ServletRequest 需要借助 RequestContextHolder,

对于分布式应用,基于ThreadLocal的实现是有很大瓶颈的

拦截器和过滤器的执行顺序

Java拦截器Interceptor和过滤器Filte的执行顺序和区别

实现原理不同

过滤器和拦截器 底层实现方式大不相同,过滤器 是基于函数回调的,拦截器 则是基于Java的反射机制(动态代理)实现的。

1、拦截器是基于java的反射机制的,而过滤器是基于函数回调
2、过滤器依赖与servlet容器,而拦截器不依赖与servlet容器
3、拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用
4、拦截器可以访问action上下文、值栈里的对象,而过滤器不能
5、在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次

使用范围不同

我们看到过滤器 实现的是 javax.servlet.Filter 接口,而这个接口是在Servlet规范中定义的,也就是说过滤器Filter 的使用要依赖于Tomcat等容器,导致它只能在web程序中使用。

而拦截器(Interceptor) 它是一个Spring组件,并由Spring容器管理,并不依赖Tomcat等容器,是可以单独使用的。不仅能应用在web程序中,也可以用于Application、Swing等程序中。

拦截的请求范围不同

项目启动过程中发现,过滤器的init()方法,随着容器的启动进行了初始化。
执行顺序 :Filter 处理中 -> Interceptor 前置 -> 我是controller -> Interceptor 处理中 -> Interceptor 处理后

Filter 处理中
Interceptor 前置
Interceptor 处理中
Interceptor 后置
Filter 处理中

过滤器Filter执行了两次,拦截器Interceptor只执行了一次。这是因为过滤器几乎可以对所有进入容器的请求起作用,而拦截器只会对Controller中请求或访问static目录下的资源请求起作用。

注入Bean情况不同
控制执行顺序不同
其他参考

springboot过滤器/拦截器/AOP区别与执行顺序
拦截器和过滤器的执行顺序和区别

ThreadLocal

史上最全ThreadLocal 详解(一)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值