拦截器的简介
-
SpringMvc的拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行
预处理
和
后处理
。开发者可以自己定义一些拦截器来实现特定的功能。 -
但是相对于过滤器而言,拦截器要的控制更加的细节,拦截器可以在三个地方进行执行
1、在请求到达Controller控制器之前,通过拦截器执行一段代码
2、在控制器执行之后,通过拦截器执行一段代码,此时只是Controller执行完毕视图还没有开始渲染
3、在整个请求结束的时候还可以通过拦截器执行一段代码 -
使用拦截器的方法:
1、创建支持它的@Component类,并且它实现Handlerlnterceptor接口
2、实现WebMVCConfigure配置器,注册到spring容器中,添加拦截路径和放行路径 -
过滤器与拦截器的区别:
过滤器
:
1、过滤器依赖于servlet容器,是servlet规范中的一部分,任何java web工程都可以使用
2、在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截
3、过滤器只能在容器初始化时被调用一次,在action的生命周期中
4、过滤器不能访问action上下文、堆栈里的对象
5、过滤器是基于函数回调
6、过滤器不能获取IOC容器中的各个bean
拦截器
:
1、拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用
2、拦截器只会拦截访问的控制器方法(只能对action请求起作用),如果访问的是jsp/html/css/image/js是不会进行拦截的
3、拦截器是AOP思想的具体应用。
4、拦截器可以多次被调用
5、拦截器可以访问action上下文、堆栈里的对象
6、拦截器不依赖于servlet容器
7、拦截器是基于java的反射机制的
8、拦截器可以获取IOC容器中的各个bean,在拦截器里注入一个service,可以调用业务逻辑。
9、拦截器是在DispatcherServlet这个servlet中执行的,因此所有的请求最先进入Filter,最后离开Filter,
其顺序如下:
Filter- >Interceptor.preHandle-> Handler- >Interceptor.postHandle->lnterceptor.afterCompletion-> Filter -
拦截器的应用场景
由于拦截器本质上是面向切面编程(AOP) ,符合横切关注点的功能都可以放在拦截器中来实现,主要的应用场景包括:
1、登录验证,判断用户是否登录。
2、权限验证,判断用户是否有权限访问资源,如校验token
3、日志记录,记录请求操作日志(用户ip, 访问时间等),以便统计请求访问量。
4、处理cookie. 本地化、国际化、主题等。
5、性能监控,监控请求处理时长等。