SpringMVC框架中的拦截器
1. 拦截器的概述
- SpringMVC框架中的拦截器用于对处理器进行预处理和后处理的技术。
- 可以定义拦截器链,连接器链就是将拦截器按着一定的顺序结成一条链,在访问被拦截的方法时,拦截器链中的拦截器会按着定义的顺序执行。
- 拦截器和过滤器的功能比较类似,有区别
- 过滤器是Servlet规范的一部分,任何框架都可以使用过滤器技术。
- 拦截器是SpringMVC框架独有的。
- 过滤器配置了/*,可以拦截任何资源。
- 拦截器只会对控制器中的方法进行拦截。
- 拦截器也是AOP思想的一种实现方式
- 想要自定义拦截器,需要实现HandlerInterceptor接口。
2. 自定义拦截器步骤
创建类,实现HandlerInterceptor接口,重写需要的方法
在方法中可以做一些功能判断 , 例如是否登录 , 如果未登录 , 则重定向到XX页面 .
/**
* 自定义拦截器1
* @author rt
*/
public class MyInterceptor1 implements HandlerInterceptor{
/**
* controller方法执行前,进行拦截的方法
* return true放行
* return false拦截
* 可以使用转发或者重定向直接跳转到指定的页面。
*/
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
System.out.println("拦截器执行了...");
return true;
}
}
3. 在springmvc.xml中配置拦截器类
<!-- 配置拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<!-- 哪些方法进行拦截 -->
<mvc:mapping path="/user/*"/>
<!-- 哪些方法不进行拦截
<mvc:exclude-mapping path=""/>
-->
<!-- 注册拦截器对象 -->
<bean class="com.itheima.demo1.MyInterceptor1"/>
</mvc:interceptor>
</mvc:interceptors>
4. HandlerInterceptor接口中的方法
-
preHandle
方法是controller方法执行前拦截的方法- 可以使用request或者response跳转到指定的页面
return true
放行,执行下一个拦截器,如果没有拦截器,执行controller中的方法。return false
不放行,不会执行controller中的方法。
-
postHandle
是controller方法执行后执行的方法,在JSP视图执行前。- 可以使用request或者response跳转到指定的页面
- 如果指定了跳转的页面,那么controller方法跳转的页面将不会显示。
-
postHandle
方法是在JSP执行后执行- request或者response不能再跳转页面了
4.5 配置多个拦截器
-
再编写一个拦截器的类
-
配置2个拦截器
<!-- 配置拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<!-- 哪些方法进行拦截 -->
<mvc:mapping path="/user/*"/>
<!-- 哪些方法不进行拦截
<mvc:exclude-mapping path=""/>
-->
<!-- 注册拦截器对象 -->
<bean class="com.itheima.demo1.MyInterceptor1"/>
</mvc:interceptor>
<mvc:interceptor>
<!-- 哪些方法进行拦截 -->
<mvc:mapping path="/**"/>
<!-- 注册拦截器对象 -->
<bean class="com.itheima.demo1.MyInterceptor2"/>
</mvc:interceptor>
</mvc:interceptors>
- 多个拦截器执行方法的顺序
-
preHandle
方法顺序执行 :
A拦截器 - B拦截器 - C拦截器 - … - controller中的方法 -
postHandle
方法倒序执行 :
controller中的方法 - …- C拦截器 - B拦截器 - A拦截器 -
postHandle
方法倒序执行 :
controller中的方法 - …- C拦截器 - B拦截器 - A拦截器