spring aop(spring interceptor), springmvc interceptor, servlet Filter有什么区别?
在spring中实现拦截功能时,有几个比较容易混淆的概念
spring aop,spring interceptor,springmvc interceptor
先总体上分析一下上面的3个术语
看一下spring aop功能的继承关系图
可以看到在spring中,Advice的实现接口就是Interceptor,所以可以看做:在spring中,spring aop与spring interceptor是一回事(可以看做AOP中的术语:增强Advice在spring中就是用interceptor来表征的)。
Interceptor接口的实现类MethodInterceptor
拦截接口目标对象方法的执行过程,在执行方法之前先执行拦截器方法
应该实现invoke(MethodInvocation)方法来修改 目标对象方法的行为
接下来来看spring interceptor与springmvc interceptor区别
对于springmvc,有两种方式配置拦截器。
一是实现HandlerInterceptor接口
二是extends HandlerInterceptorAdapter类
可以看到springmvc中的拦截器是用来拦截请求的,在MethodInterceptor之前执行
而MethodInterceptor是spring AOP项目中的拦截器,它拦截的目标是方法,即使其不是Controller中的请求方法。
参考:SpringMVC项目中,什么情况在控制层使用的AOP,什么情况使用拦截器?
“HandlerInterceptor和servlet的Filter比较相似,是一个链式的处理模式,每个请求都会在这个链下跑一遍,实际上很多请求我们是不想去处理的,如果在方法里判断显得很不spring.而自己用AOP实现,一切皆可配置,不需要的方法不去拦截(配合annotation使用)”
总结来说:spring aop与spring interceptor基本上含义相同,而spring interceptor与springmvc interceptor在功能上有区别,springmvc interceptor是拦截请求,而spring interceptor更为灵活
除了spring提供的拦截功能外,还有Servlet本身提供的Filter也可以实现拦截功能,在springmvc下使用Filter会拦截所有请求,可以使用其做全局的拦截。
另外如果你想修改HttpServletRequest中的请求参数,那么可以使用Filter+HttpServletRequestWrapper来实现,如在gateway统一对前端传递过来的user token做处理,转换为后端使用的userid