1.什么是拦截器
SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理,开发者可以自己定义一些拦截器来实现特定的功能
过滤器与拦截器的区别:拦截器是AOP思想的具体应用(即拦截器的实现原理就是AOP横切增强,不会修改源码)
- 过滤器
- servlet规范中的一部分,任何java web工程都可以使用
- 在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截
- 拦截器
- 拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用
- 拦截器只会拦截访问控制器的方法的请求, 如果访问的是jsp/html/css/image/js这些静态资源,是不会进行拦截的(这一点就比过滤器好,因为过滤器不管请求什么,它都会过滤一遍,比较占用资源和时间)
2.怎么使用拦截器/怎么自定义拦截器
要使用拦截器,我们必须定义一个类去实现HandlerInterceptor 接口
- 新建一个子model:SpringMVC-07-Interceptor,并将其改为WEB项目
- 配置web.xml中的DispatcherServlet、CharacterEncodingFilter和session
- 配置spring容器中的注解驱动、过滤静态资源、扫描包和视图解析器
- 创建视图解析器对应的jsp文件夹
- 创建一个controller测试环境是否搭建成功
3.代码实现
- 创建一个类实现拦截器
package com.thhh.config;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class MyInterceptor implements HandlerInterceptor{
//1、controller执行前执行,返回为true将放行请求,返回为false请求将不能到达controller的对应方法中
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("======方法执行前======");
return true;
}
//2、controller执行后执行
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("======方法执行后======");
}
//3、清理操作
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("======清理操作======");
}
}
既然拦截器的实现原理是AOP,所以要使用它还是要去spring配置文件中进行mvc拦截器的配置
注意:上面我们写的是" /** “,” / ** “和” /* “是不一样的,” /* “之会匹配过滤所有的一级请求,如"项目名称/第一级请求/第二级请求”,对于第一级请求之后的请求它是不管的;而" / ** "是指不管你是多少级的请求,都要走我这个过滤器
4.测试
通过测试结果我们可以验证前面说的这3个方法的执行时期,对于postHandle()方法,我们一般用它来记录日志