springMvc拦截器的执行顺序!
拦截器的各个方法的作用:
/** * 登录验证拦截器 */
public class Intercepter implements HandlerInterceptor {
/*
* 执行时机:视图已经被解析完毕,类似try catch 后的finally,追踪错误 */ public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object object, Exception exception) throws Exception { } /** * 执行时机:controller执行完,视图解析器没有把视图解析成页面, * 对视图做统一的修改,主要体现在Model上,可以追加数据 */ public void postHandle(HttpServletRequest request, HttpServletResponse response, Object object, ModelAndView mv) throws Exception { Map<String,Object> map=mv.getModel();
map.put("test","append something"); } /** * 执行时机:在执行controller之前来执行 * 返回值类型:boolean:true代表放行可以访问controller,false不可以访问controller */ public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object object) throws Exception { return false; } }
写了两个拦截器,配置如下:
<!-- 配置拦截器 --> <mvc:interceptors> <!-- 多个拦截器,顺序执行 --> <mvc:interceptor> <mvc:mapping path="/**"/><!-- 表示所有的url,包括子url路径 --><!-- 某一模块的拦截:/myPath/**, 拦截所有的请求/**--> <bean class="com.interceptors.EncodingInterceptor"></bean> </mvc:interceptor> <!--配置登陆拦截器 --> <mvc:interceptor> <mvc:mapping path="/**"/> <bean class="com.interceptors.LoginHandlerIntercepter"></bean> </mvc:interceptor> </mvc:interceptors>
没写什么逻辑,就打印了log,LoginHandlerIntercepter中的log是01
结果简略如下:
preHandle.........
preHandle01.........
...
...
...
postHandle01.........
postHandle.........
...
...
...
afterCompletion01.........
afterCompletion.........
可以看出,按照拦截器的配置顺序先执行了字符拦截器,后执行了登录验证的拦截器;
但是:preHandler是按照拦截器的配置顺序执行的,而postHandler和afterCompletion是按照拦截器的配置顺序的倒序执行的
所以 :
如果统一日志处理器拦截器,需要改拦截器prehandler一定要返回true,且将它放在拦截器配置的第一个位置;
如果登陆认证拦截器,放在拦截器的配置中的第一个位置(有日志处理的话,放在日志处理下面);
如果有权限校验拦截器,则放在登陆拦截器之后,因为登陆通过后,才可以进行校验权限;
暂且记录这些。。。。