1 什么是拦截器?
SpringMVC的拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理,用户可以自定义一些拦截器来实现特定的功能.它也是aop思想的具体应用 .
2 拦截器和过滤器的区别
过滤器 是servlet规范中的一部分,任何java web项目都可以使用.
拦截器 是springMVC框架独有的, 只有使用SpringMVC项目才可以使用拦截器.
过滤器 在url-pattern 中配置/*之后,可以对所有访问的资源拦截.
拦截器 它是只会拦截访问的控制器方法,如果访问jsp , html ,css ,image 或者 js 是不会进行拦截的
3 实现拦截器的两种方法
实现拦截器可以实现接口 HandlerInterceptor , 或者继承 AbstractInterceptor
4.方法解析
/**
* 自定义拦截器
*
*/
public class HandlerInterceptorDemo1 implements HandlerInterceptor {
/**
* 预处理方法,在controller方法前执行
* return true , 放行 执行下一个拦截器, 如果没有进入 controller中的方法
* return false 不放行
* */
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle 拦截器拦截了");
return true;
}
/**
* 后处理方法,在controller方法后执行
* */
@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 方法执行了");
}
}
5 拦截器配置
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" /><!-- 用于指定对拦截的 url -->
<mvc:exclude-mapping path=""/><!-- 用于指定排除的 url-->
<bean id="handlerInterceptorDemo1" class="com.itheima.web.interceptor.HandlerInterceptorDemo1">
</bean>
</mvc:interceptor>
<!--第二个拦截器-->
<mvc:interceptor>
<mvc:mapping path="/**" /><!-- 用于指定对拦截的 url -->
<mvc:exclude-mapping path=""/><!-- 用于指定排除的 url-->
<bean id="handlerInterceptorDemo2" class="com.itheima.web.interceptor.HandlerInterceptorDemo2">
</bean>
</mvc:interceptor>
</mvc:interceptors>