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区别与执行顺序
拦截器和过滤器的执行顺序和区别