SpringMVC的拦截器
其实拦截器和Servlet的Filter是类似的,基本上与Flilter的原理一致
拦截器的概述
- SpringMVC框架中的拦截器用于对处理器进行预处理和后处理的技术。
- 可以定义拦截器链,连接器链就是将拦截器按着一定的顺序结成一条链,在访问被拦截的方法时,拦截器链 中的拦截器会按着定义的顺序执行。
- 拦截器和过滤器的功能比较类似,有区别
- 过滤器是Servlet规范的一部分,任何框架都可以使用过滤器技术。
- 拦截器是SpringMVC框架独有的。
- 过滤器配置了/*,可以拦截任何资源。
- 拦截器只会对控制器中的方法进行拦截。
- 拦截器也是AOP思想的一种实现方式
- 想要自定义拦截器,需要实现HandlerInterceptor接口。
自定义拦截器
- preHandle方法是controller方法执行前拦截的方法
- 可以使用request或者response跳转到指定的页面
- return true放行,执行下一个拦截器,如果没有拦截器,执行controller中的方法。
- return false不放行,不会执行controller中的方法。
- postHandle是controller方法执行后执行的方法,在JSP视图执行前。
- 可以使用request或者response跳转到指定的页面
- 如果指定了跳转的页面,那么controller方法跳转的页面将不会显示。
- postHandle方法是在JSP执行后执行
- request或者response不能再跳转页面了
public class MyInterceptor implements HandlerInterceptor {
/**
* @Description:
* @Param: [request, response, handler]
* @return: boolean
* true代表通过,执行下一个拦截器或者Controller
* false代表不通过,一般会使用Servlet API进行重定向或者跳转到其他页面
* @Author: 10_Addtiply
* @Date: 2021/2/18
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("拦截器1的preHandle");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("拦截器1的postHandle");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("拦截器1的afterCompletion");
}
}
具体的执行顺序如下,假设配置情况如下:
<!-- 配置拦截器 -->
<mvc:interceptors>
<!-- 配置单个拦截器,其中配置的顺序决定了拦截器的顺序 -->
<mvc:interceptor>
<!-- 配置哪些方法进行拦截 -->
<mvc:mapping path="/hello/*"/>
<bean class="com.billsjc.interceptor.MyInterceptor"></bean>
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/hello/*"/>
<bean class="com.billsjc.interceptor.MyInterceptor2"></bean>
</mvc:interceptor>
</mvc:interceptors>
最终执行顺序如下:
拦截器1的preHandle
拦截器2的preHandle
testString...(控制器方法)
拦截器2的postHandle
拦截器1的postHandle
success.jsp 加载完毕
拦截器2的afterCompletion
拦截器1的afterCompletion