十一、拦截器
# 11.1、拦截器的配置
SpringMVC中的拦截器用于拦截控制器方法的执行
SpringMVC中的拦截器需要实现HandlerInterceptor
SpringMVC的拦截器必须在SpringMVC的配置文件中进行配置:
<mvc:interceptors>
<bean class="com.atguigu.interceptor.FirstInterceptor"></bean>
<ref bean="firstInterceptor"></ref>
<!-- 以上两种配置方式都是对DispatcherServlet所处理的所有的请求进行拦截 -->
<mvc:interceptor>
<!--/*表示请求路径下的一层请求,/**表示任意层请求-->
<mvc:mapping path="/**"/>
<mvc:exclude-mapping path="/testRequestEntity"/>
<ref bean="firstInterceptor"></ref>
</mvc:interceptor>
<!--
以上配置方式可以通过ref或bean标签设置拦截器,通过mvc:mapping设置需要拦截的请求,
通过mvc:exclude-mapping设置需要排除的请求,即不需要拦截的请求
-->
</mvc:interceptors>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 11.2、拦截器的三个抽象方法
SpringMVC中的拦截器有三个抽象方法:
preHandle:控制器方法执行之前执行preHandle(),其boolean类型的返回值表示是否拦截或放行,返回true为放行,即调用控制器方法;返回false表示拦截,即不调用控制器方法
postHandle:控制器方法执行之后执行postHandle()
afterCompletion:处理完视图和模型数据,渲染视图完毕之后执行afterCompletion()
就算请求没有匹配(404),拦截器的三个方法也会执行
@Component
public class FirstInterceptor implements HandlerInterceptor {
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("FirstInterceptor-->preHandle");
return true;
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("FirstInterceptor-->postHandle");
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("FirstInterceptor-->afterCompletion");
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 11.3、多个拦截器的执行顺序
①若每个拦截器的preHandle()
都返回true
此时多个拦截器的执行顺序和拦截器在SpringMVC的配置文件的配置顺序有关:
preHandle()
会按照配置的顺序执行,而postHandle()
和afterCompletion()
会按照配置的反序执行
<mvc:interceptors>
<ref bean="firstInterceptor"></ref>
<ref bean="secondeInterceptor"></ref>
</mvc:interceptors>
1
2
3
4
2
3
4
FirstInterceptor-->preHandle
SecondeInterceptor-->preHandle
SecondeInterceptor-->postHandle
FirstInterceptor-->postHandle
SecondeInterceptor-->afterCompletion
FirstInterceptor-->afterCompletion
1
2
3
4
5
6
2
3
4
5
6
②若某个拦截器的preHandle()
返回了false
preHandle()
返回false和它之前的拦截器的preHandle()
都会执行,postHandle()
都不执行,返回false的拦截器之前的拦截器的afterCompletion()
会执行
设置SecondInterceptor的preHandle()
返回false,结果如下:
FirstInterceptor-->preHandle
SecondeInterceptor-->preHandle
FirstInterceptor-->afterCompletion
1
2
3
2
3
编辑 (opens new window)
上次更新: 2024/05/30, 07:49:34