![0cd775bed3d4e0aca95d566890b710a4.png](https://i-blog.csdnimg.cn/blog_migrate/a2986edccd99909345b9e63fc437ad02.jpeg)
在学习拦截器之前,我们学习了过滤器以及AOP面向切面思想,
所以可以理解为拦截器是一个比过滤器更小更精准的过滤器,且作用于控制单元
过滤器
过滤器针对的是你的每一个请求
过滤器一共做3件事情
- [1]到达目标资源之前的预处理操作
- [2]执行下一个过滤器或者目标资源
- [3]离开服务器之前的处理操作
拦截器
拦截器主要针对的就是控制单元,我们可以理解成拦截器就是一个细化的过滤器
拦截器实现的思想就是Spring AOP
a、切点--控制单元.
b、通知--拦截器的方法
c、织成切面
![d4756927a11e2f93d1c8fbd97c988f7d.png](https://i-blog.csdnimg.cn/blog_migrate/48c4ca13c4473cd0327676301a4956a7.jpeg)
1.编写拦截器类 实现 HandlerInterceptor 接口 重写三个方法
1.1 preHandle 返回值是布尔类型的 若return true 即放行
执行的时机:
在进入控制单元方法之前
这个方法的返回值决定了是否继续执行控制单元的方法
- 返回值是true --就进入控制单元继续执行
- 返回值是false--就不会继续执行
即将执行控制单元中方法对象
![e4aa3ba7e70b17a7948b10e212939b8b.png](https://i-blog.csdnimg.cn/blog_migrate/aa2bd36e7dd41506fb178c2879efcf91.jpeg)
作用:
![82cf2b48f4fac9a6c0ba46526713a71f.png](https://i-blog.csdnimg.cn/blog_migrate/504f8c26f0fbd215825d5bfaeac257eb.png)
![dfd6080c2cd851f22df5286d7747aaf7.png](https://i-blog.csdnimg.cn/blog_migrate/7898b9804beb94c8b360f7d874b5f61f.png)
1.2 postHandle
执行的时机:
在数据处理之后进行处理
![df2a30c35e99a8e8f70634960438178c.png](https://i-blog.csdnimg.cn/blog_migrate/06b03988d355e17bcbd08ba933ccf212.png)
作用:
![06cd62cbef5591497e928637432c0339.png](https://i-blog.csdnimg.cn/blog_migrate/3a9dc996eb52a771fd121a4759a17ad8.jpeg)
![3a908e0a4744f474580e4e4a4746752e.png](https://i-blog.csdnimg.cn/blog_migrate/ec7f5373619704ce9e8082109d1d4952.png)
![66bb996d68c5b0d73de0263f296c9428.png](https://i-blog.csdnimg.cn/blog_migrate/8c50949cdbd915056c097a6c964a38af.png)
1.3 afterCompletion
执行的时机:
在进行页面渲染的时候
![dd712c8ab60069c5388017c2ac4809da.png](https://i-blog.csdnimg.cn/blog_migrate/3610b39904a5c562861559cd67435079.png)
作用
![8822fe81b5f3b2ad9f0c76d55f359e61.png](https://i-blog.csdnimg.cn/blog_migrate/0cc1e1763741d988d0e7c1b67ff3bba4.png)
![679842063a7984b7b19f3ac7eab43088.png](https://i-blog.csdnimg.cn/blog_migrate/505bedccc7978e2bd6844ea1328364d7.png)
2在applicationContext-mvc.xml中进行配置
![v2-578194deebdea130a782799847a7dce7_b.jpg](http://img-02.proxy.5ce.com/view/image?&type=2&guid=d0ee36dc-bb38-eb11-8da9-e4434bdf6706&url=https://pic4.zhimg.com/v2-578194deebdea130a782799847a7dce7_b.jpg)
![3e64d3deb2be5ef66f46514373c6fabc.png](https://i-blog.csdnimg.cn/blog_migrate/47b17cbf8af54cfe16936ef696f80917.jpeg)
package com.lin.interceptor;
import org.apache.log4j.Logger;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class LogInterceptor implements HandlerInterceptor {
private Logger logger = Logger.getLogger(LogInterceptor.class);
/**
* 在进入控制器方法前被调用的方法
*
* @param request 请求对象
* @param response 响应对象
* @param handler 被拦截的控制器方法
* @return true表示允许访问, false表示终止访问. 如果返回false, 需要提示客户端
* @throws Exception
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
logger.error("[日志拦截: 1] - preHandle - 控制器被调用前执行 - " + handler);
return true;
}
/**
* 控制器方法调用结束, 有返回结果之后, 调用postHandle方法
*
* @param request 请求对象
* @param response 响应对象
* @param handler 控制器方法
* @param modelAndView 控制器方法返回的结果
* @throws Exception
*/
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
logger.error("[日志拦截: 2] - postHandle - 控制器调用后执行 - " + handler);
}
/**
* 本次流程结束后会被调用的方法, 通常用于最终的异常处理
*
* @param request 请求对象
* @param response 响应对象
* @param handler 控制器方法
* @param ex 异常对象
* @throws Exception
*/
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
logger.error("[日志拦截: 3] - afterCompletion - 流程结束 - " + handler);
}
}
拦截器的原理
![d4756927a11e2f93d1c8fbd97c988f7d.png](https://i-blog.csdnimg.cn/blog_migrate/48c4ca13c4473cd0327676301a4956a7.jpeg)
![e4aa3ba7e70b17a7948b10e212939b8b.png](https://i-blog.csdnimg.cn/blog_migrate/aa2bd36e7dd41506fb178c2879efcf91.jpeg)
![9da07dfbf4980a70f9289e8a1ae3fb38.png](https://i-blog.csdnimg.cn/blog_migrate/fbe4baaafa476da2c24ef5b57029d3f8.png)
![ae8c382ec98da30497991d46fec7bb79.png](https://i-blog.csdnimg.cn/blog_migrate/97933d1b9976a6ede2bc11f9136b5b94.png)
![4d9558ba87c77bfbe281909e7219f1da.png](https://i-blog.csdnimg.cn/blog_migrate/0e15201779741ba483371ca6fb54aad5.png)
多重拦截器
先进后出,越后面的越先出
![6c84d633dbc7459a28a091426990fd43.png](https://i-blog.csdnimg.cn/blog_migrate/a4028f53bd422871fc061f8f5e833a1c.png)
细节
拦截具体和拦截所有
![dd39d19fe8940dfacca1c83695a461f6.png](https://i-blog.csdnimg.cn/blog_migrate/217b5afad533176822b7f241401f1b76.png)
![389aa0a3783f22681d8968e8a3290765.png](https://i-blog.csdnimg.cn/blog_migrate/d748bbe8344d655ee5810190ce7cd7b3.jpeg)