目录
一、监听器、过滤器和拦截器对比
1、Servlet
处理 Request 请求和 Response 响应。
2、过滤器(Filter)
对 Request 请求起到过滤的作用,作用在 Servlet 之前,如果配置为 /* 可以对所有的资源访问(servlet、js/css 静态资源等)进行过滤处理。
3、监听器(Listener)
实现了 javax.servlet.ServletContextListener 接口的服务器端组件,它随 Web 应用的启动而启动,只初始化一次,然后会一直运行监视,随 Web 应用的停止而销毁。
作用一:做一些初始化工作,web 应用中 spring 容器启动 ContextLoaderListener;
作用二:监听 web 中的特定事件,比如 HttpSession,
ServletRequest 的创建和销毁;变量的创建、销毁和修改等。可以在某些动作前后增加处理,实现监控,比如统计在线人数,利用 HttpSessionLisener 等。
4、拦截器(Interceptor)
是 SpringMVC、Struts 等表现层框架自己的,不会拦截 jsp/html/css/image 的访问等,只会拦截访问的控制器方法(Handler)。
从配置的⻆度也能够总结发现:serlvet、filter、listener 是配置在 web.xml 中的,而 interceptor 是配置在表现层框架自己的配置文件中的。
1)在 handler 业务逻辑执行之前拦截一次;
2)在 handler 逻辑执行完毕但未跳转⻚面之前拦截一次;
3)在跳转⻚面之后拦截一次;
二、拦截器的执行流程
在运行程序时,拦截器的执行是有一定顺序的,该顺序与配置文件中所定义的拦截器的顺序相关。
单个拦截器,在程序中的执行流程如下图所示:
- 程序先执行 preHandle() 方法,如果该方法的返回值为 true,则程序会继续向下执行处理器中的方法,否则将不再向下执行。
- 在业务处理器(即控制器 Controller 类)处理完请求后,会执行 postHandle() 方法,然后会通过 DispatcherServlet 向客户端返回响应。
- 在 DispatcherServlet 处理完请求后,才会执行 afterCompletion() 方法。
三、多个拦截器的执行流程
多个拦截器(假设有两个拦截器 Interceptor1 和 Interceptor2,并且在配置文件中,Interceptor1 拦截器配置在前),在程序中的执行流程如下图所示:
从图可以看出,当有多个拦截器同时工作时,它们的 preHandle() 方法会按照配置文件中拦截器的配置顺序执行,而它们的 postHandle() 方法和 afterCompletion() 方法则会按照配置顺序的反序执行。
四、示例代码
1、自定义 Spring MVC 拦截器
import org.springframework