拦截器(Interceptor)简介
SpringMVC 中的拦截器(Interceptor)相当于 Java Web 中的过滤器(Filter),通过拦截器,可以实现对请求的预处理和后处理
自定义拦截器
创建拦截器类,实现 HandleInterceptor 接口
public class MyInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle...");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("postHandle...");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("afterCompletion...");
}
}
- preHandle:在目标方法执行前执行
- postHandle:在目标方法执行后,渲染视图前执行
- afterCompletion:整个请求结束后执行
preHandle 方法中的布尔返回值,表示请求是否继续,如果为 false 则直接将请求拦截,不再往下传递
postHandle 方法中的 ModelAndView 参数可以进行修改,以改变返回的视图和模型
配置拦截器
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="Interceptor.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
/** 表示所有资源,如 /xxx/** 表示 xxx 下的所有资源
<mvc:exclude-mapping path=""/>
可以指定哪些资源不进行拦截,如需登录才可访问的内容,可配置登录页面不进行拦截,而其余页面进行拦截判断是否登录
Controller 中创建业务方法进行测试
@RequestMapping(value = "/interceptor")
@ResponseBody
public void interceptor() {
System.out.println("interceptor...");
}
通过如下请求进行测试
http://localhost:8080/user/interceptor
结果如下
拦截器执行顺序
单个拦截器
多个拦截器
在配置文件中,将 Interceptor1 配置在 Interceptor2 之前
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="Interceptor.Interceptor1"/>
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="Interceptor.Interceptor2"/>
</mvc:interceptor>
</mvc:interceptors>