SpringMVC处理器拦截器
类似于servlet的filter过滤器
* 拦截器定义
public class HandlerInterceptor1 implements HandlerInterceptor { /** * 处理器方法返回视图后调用 * 可以用来记录日志,并且捕获异常信息 */ @Override public void afterCompletion(HttpServletRequest req, HttpServletResponse rsp, Object arg2, Exception arg3) throws Exception { System.out.println("afterCompletion1.........."); } /** * 处理器方法执行后但是没有返回视图调用 * 这里可以在返回model前,对模型数据进行加工 */ @Override public void postHandle(HttpServletRequest req, HttpServletResponse rsp, Object arg2, ModelAndView arg3) throws Exception { System.out.println("postHandle1............"); } /** * 处理器方法调用前调用 * true:表示继续执行 false:表示请求被拦截 * 这里可以做用户登录校验 */ @Override public boolean preHandle(HttpServletRequest req, HttpServletResponse rsp, Object arg2) throws Exception { System.out.println("preHandle1............"); return true; } }
HanderInterceptor2是上面的复制文件,打印的为xx2...........
* xml中配置拦截器
<!-- 配置拦截器 --> <mvc:interceptors> <mvc:interceptor> <!-- 所有请求进入拦截器1 --> <mvc:mapping path="/**"/> <bean class="cn.bing.handlerInterceptor.HandlerInterceptor1"></bean> </mvc:interceptor> <mvc:interceptor> <!-- 所有请求进入拦截器2 --> <mvc:mapping path="/**"/> <bean class="cn.bing.handlerInterceptor.HandlerInterceptor2"></bean> </mvc:interceptor> </mvc:interceptors>
* 任意请求,拦截器的输出
preHandle1............ preHandle2............ postHandle2............ postHandle1............ afterCompletion2.......... afterCompletion1..........
说明prehandle方法按照定义的顺序调用,postHandle,afterCompletion方法按照定义逆序调用
* 将拦截器1的prehandle方法改为false,后面的仍然是true
preHandle1............
prehandle返回false,只会执行当前prehandle的方法,后面的拦截器不执行,并且不会执行controller方法
* 将拦截器2的prehandle方法修改返回为false,前面的改为false
preHandle1............ preHandle2............ afterCompletion1..........
从结果看出,拦截器2prehandle方法改为false后,拦截器1的postHandler不会执行,并且拦截器2的postHandler不执行,afterCompletion1不执行
结论:
* postHandler 在所有拦截器返回成功才去调用
* afterCompletion方法只有perhandle方法返回true才去调用
用户登录校验
在拦截器的prehandle方法里面校验session存在,不存在,重定向到登录页面