• 初学springMVC的拦截器


    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,且将它放在拦截器配置的第一个位置;
             如果登陆认证拦截器,放在拦截器的配置中的第一个位置(有日志处理的话,放在日志处理下面);
             如果有权限校验拦截器,则放在登陆拦截器之后,因为登陆通过后,才可以进行校验权限;

     暂且记录这些。。。。

  • 相关阅读:
    Java 线程终止
    Android Jetpack架构之ProcessLifeCycleOwner
    Android Jetpack架构之LifecycleService
    Android Jetpack架构之Lifecycle
    Android Jetpack架构
    深入理解JNI技术
    Java虚拟机类加载器机制
    Java HashMap、HashTable、ConcurrentHashMap区别
    Java内存分配策略
    Java 方法分派
  • 原文地址:https://www.cnblogs.com/xh_Blog/p/7605493.html
Copyright © 2020-2023  润新知