1.拦截器的配置
springMVC的拦截器用于拦截控制器方法的执行
SpringMVC中的拦截器需要实现HandlerInterceptor接口
SpringMVC的拦截器必须在SpringMVC的配置文件中进行配置
<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设置需要排除的请求,即不
需要拦截的请求 -->
2.拦截器的三个抽象方法
- preHandle:在控制器方法执行之前执行preHandle(),其boolean类型的返回值表示是否拦截或者放行,返回true表示放行,返回false表示进行拦截,即不同调用控制器方法
- postHandle(),在控制器方法执行之后执行
- afterComplation(),处理完视图和模型数据,渲染视图完毕后执行
@Component
public class TestInterceptor implements HandlerInterceptor {
//控制器方法执行之前执行preHandle(),其boolean类型的返回值表示是否需要拦截或放行,返回
//true为放行,即调用控制器方法,返回false表示拦截,即不调用控制器方法
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("TestInterceptor --> preHandle ");
return true;
}
//控制器执行之后执行postHandle()
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("TestInterceptor --> postHandle ");
}
//处理完视图和数据模型,渲染试图完毕后执行afterCompletion()
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("TestInterceptor --> afterCompletion ");
}
}
3.多个拦截器的执行顺序
a.若每个拦截器的preHandle()都返回true
此时多个拦截器的执行顺序和拦截器在SpringMVC的配置文件的配置顺序有关:preHandle()会按照配置的顺序执行,而postHandle()和afterComplation()会按照配置的反序执行
b>若某个拦截器的preHandle()返回了false
preHandle()返回false和它之前的拦截器的preHandle()都会执行,postHandle()都不执行,返回false的拦截器之前的拦截器的afterComplation()会执行