有两种方法配置spring的拦截器
1. 实现接口: HandleInterceptor
public class MyInterceptor1 implements HandlerInterceptor {
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object obj, Exception e) throws Exception {
System.out.println("最后执行!!!一般用于释放资源!!");
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object obj, ModelAndView model) throws Exception {
System.out.println("Action执行之后,生成视图之前执行!!");
}
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object obj) throws Exception {
System.out.println("action之前执行!!!");
return true; // 继续执行action
}
}
a) preHandle
该方法在action执行前执行,可以实现对数据的预处理,比如:编码、安全控制等。
如果方法返回true,则继续执行action。
b) postHandle
该方法在action执行后,生成视图前执行。在这里,我们有机会修改视图层数据。
c) afterCompletion
最后执行,通常用于释放资源,处理异常。我们可以根据ex是否为空,来进行相关的异常处理。
因为我们在平时处理异常时,都是从底层向上抛出异常,最后到了spring框架从而到了这个方法中。
2. 继承适配器: HandleInterceptorAdapter
public class MyInterceptor2 extends HandlerInterceptorAdapter {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("MyInterceptor2.preHandle()");
return true; // 继续执行action
}
}
3. 配置user-servlet.xml
方案1:
<!-- 配置自定义拦截器 -->
<mvc:interceptors>
<bean class="com.zdp.interceptor.MyInterceptor1"></bean> <!-- 拦截所有的url! -->
</mvc:interceptors>
方案2:
<!-- 配置自定义拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/user/add" /> <!-- 只拦截添加用户 -->
<bean class="com.zdp.interceptor.MyInterceptor2"></bean>
</mvc:interceptor>
</mvc:interceptors>