一、正常流程下的拦截器(全部放行)

1.springMVC中拦截器实现这个接口HandlerInterceptor

第一个拦截器 HandlerInterceptor1

  1.  
    public class HandlerInterceptor1 implements HandlerInterceptor {
  2.  
    //进入 Handler方法之前执行
  3.  
    //用于身份认证、身份授权
  4.  
    //比如身份认证,如果认证通过表示当前用户没有登陆,需要此方法拦截不再向下执行
  5.  
    @Override
  6.  
    public boolean preHandle(HttpServletRequest request,
  7.  
    HttpServletResponse response, Object handler) throws Exception {
  8.  
    System.out.println("HandlerInterceptor1...preHandle");
  9.  
    //return false表示拦截,不向下执行
  10.  
    //return true表示放行
  11.  
    return true;
  12.  
    }
  13.  
    //进入Handler方法之后,返回modelAndView之前执行
  14.  
    //应用场景从modelAndView出发:将公用的模型数据(比如菜单导航)在这里传到视图,也可以在这里统一指定视图
  15.  
    @Override
  16.  
    public void postHandle(HttpServletRequest request,
  17.  
    HttpServletResponse response, Object handler,
  18.  
    ModelAndView modelAndView) throws Exception {
  19.  
    System.out.println("HandlerInterceptor1...postHandle");
  20.  
    }
  21.  
    //执行Handler完成执行此方法
  22.  
    //应用场景:统一异常处理,统一日志处理
  23.  
    @Override
  24.  
    public void afterCompletion(HttpServletRequest request,
  25.  
    HttpServletResponse response, Object handler, Exception ex)
  26.  
    throws Exception {
  27.  
    System.out.println("HandlerInterceptor1...afterCompletion");
  28.  
    }
  29.  
    }

第二个拦截器 HandlerInterceptor2

  1.  
    public class HandlerInterceptor2 implements HandlerInterceptor {
  2.  
    //进入 Handler方法之前执行
  3.  
    //用于身份认证、身份授权
  4.  
    //比如身份认证,如果认证通过表示当前用户没有登陆,需要此方法拦截不再向下执行
  5.  
    @Override
  6.  
    public boolean preHandle(HttpServletRequest request,
  7.  
    HttpServletResponse response, Object handler) throws Exception {
  8.  
    System.out.println("HandlerInterceptor2...preHandle");
  9.  
    //return false表示拦截,不向下执行
  10.  
    //return true表示放行
  11.  
    return true;
  12.  
    }
  13.  
    //进入Handler方法之后,返回modelAndView之前执行
  14.  
    //应用场景从modelAndView出发:将公用的模型数据(比如菜单导航)在这里传到视图,也可以在这里统一指定视图
  15.  
    @Override
  16.  
    public void postHandle(HttpServletRequest request,
  17.  
    HttpServletResponse response, Object handler,
  18.  
    ModelAndView modelAndView) throws Exception {
  19.  
    System.out.println("HandlerInterceptor2...postHandle");
  20.  
    }
  21.  
    //执行Handler完成执行此方法
  22.  
    //应用场景:统一异常处理,统一日志处理
  23.  
    @Override
  24.  
    public void afterCompletion(HttpServletRequest request,
  25.  
    HttpServletResponse response, Object handler, Exception ex)
  26.  
    throws Exception {
  27.  
    System.out.println("HandlerInterceptor2...afterCompletion");
  28.  
    }
  29.  
    }

springMVC.xml中配置两个拦截器

  1.  
    <!--拦截器 -->
  2.  
    <mvc:interceptors>
  3.  
    <!--多个拦截器,顺序执行 -->
  4.  
    <mvc:interceptor>
  5.  
    <!-- /**表示所有url包括子url路径 -->
  6.  
    <mvc:mapping path="/**"/>
  7.  
    <bean class="cn.itcast.ssm.interceptor.HandlerInterceptor1"></bean>
  8.  
    </mvc:interceptor>
  9.  
    <mvc:interceptor>
  10.  
    <mvc:mapping path="/**"/>
  11.  
    <bean class="cn.itcast.ssm.interceptor.HandlerInterceptor2"></bean>
  12.  
    </mvc:interceptor>
  13.  
    </mvc:interceptors>

查看打印的日志信息

HandlerInterceptor1...preHandle
HandlerInterceptor2...preHandle

HandlerInterceptor2...postHandle
HandlerInterceptor1...postHandle

HandlerInterceptor2...afterCompletion
HandlerInterceptor1...afterCompletion

这是正常的拦截器执行流程

以上执行的拦截器是正常流程的拦截器的顺序

二、非正常情况下的拦截器(第一个拦截器放行,第二个拦截器拦截)

细心的读者会发现在拦截器中preHandle方法中的返回值我做了注解,  //return false表示拦截,不向下执行//return true表示放行

  1.  
    public class HandlerInterceptor2 implements HandlerInterceptor {
  2.  
    //进入 Handler方法之前执行
  3.  
    //用于身份认证、身份授权
  4.  
    //比如身份认证,如果认证通过表示当前用户没有登陆,需要此方法拦截不再向下执行
  5.  
    @Override
  6.  
    public boolean preHandle(HttpServletRequest request,
  7.  
    HttpServletResponse response, Object handler) throws Exception {
  8.  
    System.out.println("HandlerInterceptor1...preHandle");
  9.  
    //return false表示拦截,不向下执行
  10.  
    //return true表示放行
  11.  
    return false;
  12.  
    }

再次启动系统拦截器的执行顺序

日志打印

HandlerInterceptor1...preHandle
HandlerInterceptor2...preHandle
HandlerInterceptor1...afterCompletion

总结:

拦截器1放行,拦截器2 preHandle才会执行。

拦截器2 preHandle不放行,拦截器2 postHandle和afterCompletion不会执行。

只要有一个拦截器不放行,postHandle不会执行。

二、非正常情况下的拦截器(第一个拦截器拦截,第二个拦截器拦截)

  1.  
    public class HandlerInterceptor1 implements HandlerInterceptor {
  2.  
    //进入 Handler方法之前执行
  3.  
    //用于身份认证、身份授权
  4.  
    //比如身份认证,如果认证通过表示当前用户没有登陆,需要此方法拦截不再向下执行
  5.  
    @Override
  6.  
    public boolean preHandle(HttpServletRequest request,
  7.  
    HttpServletResponse response, Object handler) throws Exception {
  8.  
    System.out.println("HandlerInterceptor1...preHandle");
  9.  
    //return false表示拦截,不向下执行
  10.  
    //return true表示放行
  11.  
    return false;
  12.  
    }
  1.  
    public class HandlerInterceptor2 implements HandlerInterceptor {
  2.  
    //进入 Handler方法之前执行
  3.  
    //用于身份认证、身份授权
  4.  
    //比如身份认证,如果认证通过表示当前用户没有登陆,需要此方法拦截不再向下执行
  5.  
    @Override
  6.  
    public boolean preHandle(HttpServletRequest request,
  7.  
    HttpServletResponse response, Object handler) throws Exception {
  8.  
    System.out.println("HandlerInterceptor2...preHandle");
  9.  
    //return false表示拦截,不向下执行
  10.  
    //return true表示放行
  11.  
    return false;
  12.  
    }

日志打印

HandlerInterceptor1...preHandle

总结

拦截器1 preHandle不放行,postHandle和afterCompletion不会执行。

拦截器1 preHandle不放行,拦截器2不执行。

SpringMVC自定义多个拦截器执行顺序的更多相关文章

  1. Struts2的默认拦截器执行顺序

    我们在写Struts2的时候package属性默认都是差不多这样吧 <package name="packageName" namespace="/" e ...

  2. Springmvc的拦截器执行顺序及各方法作用

    实现HandlerInterceptor接口或者继承HandlerInterceptor的子类,比如Spring 已经提供的实现了HandlerInterceptor 接口的抽象类HandlerInt ...

  3. SpringMVC学习笔记九:拦截器及拦截器的简单实用

    SpringMVC中的interceptor拦截器是非常重要的,它的主要作用就是拦截指定的用户请求,并进行相应的预处理和后处理. 拦截时间点在"处理器映射器根据用户提交的请求映射出所要执行的 ...

  4. SpringMVC中使用Interceptor拦截器顺序

    一.简介 SpringMVC 中的Interceptor 拦截器也是相当重要和相当有用的,它的主要作用是拦截用户的请求并进行相应的处理.比如通过它来进行权限验 证,或者是来判断用户是否登陆,或者是像1 ...

  5. SpringMVC拦截器执行流程

    1:MyInterceptor1.MyInterceptor2这2个拦截器都放行 MyInterceptor1......preHandleMyInterceptor2......preHandle ...

  6. SpringMVC框架下的拦截器

    在eclipse的javaEE环境下:导包.... web.xml文件中的配置: <?xml version="1.0" encoding="UTF-8" ...

  7. SpringMVC总结四:拦截器简单介绍

    首先要说一下HandlerExecutionChain: HandlerExecutionChain是一个执行链,当用户的请求到达DispatcherServlet的时候,DispatcherServ ...

  8. SpringMVC中session使用&&拦截器&&乱码处理&&异常处理

    ### 1. 使用Session 通常,会在Session中存放: 1. 客户端(用户)的身份标识,通常是用户的id:2. 使用频率非常高的数据,例如显示在页面中的用户名.头像等:3. 其它的不便于使 ...

  9. SpringMVC 学习笔记(六)拦截器

    5.1.处理器拦截器简介 Spring Web MVC的处理器拦截器(如无特殊说明,下文所说的拦截器即处理器拦截器) 类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理. ...

随机推荐

  1. php学习笔记-continue和break

    这两个关键字经常被用在循环中,但作用是完全不同的. 在循环中遇到continue这个单词的时候一定要理解为skip,跳过或者略过,啥意思?就是跳过本次循环,后面的循环继续走起来,老铁. break是说 ...

  2. Luogu 4137 Rmq Problem / mex

    一个主席树题. 一开始想着直接动态开点硬搞就可以了,每次查询只要作一个类似于前缀和的东西看看区间有没有满,在主席树上二分就可以了. 但是这样是错的,因为一个权值会出现很多次……然后就错了. 所以我们考 ...

  3. Entity Framework Tutorial Basics(20):Persistence in Entity Framework

    Persistence in Entity Framework There are two scenarios when persisting an entity using EntityFramew ...

  4. (树)判断二叉树是否为BST

    题目:判断一颗二叉树是否为BST. 思路:其实这个问题可以有多个解决方法. 方法一:递归解决.根据BST的特性.左边的小于根节点的值,右边的大于根节点的值.并且对于每一棵子树都是如此.所以我们可以直接 ...

  5. Linux下遇到的操作 (持续更新……)

    1.作业让写一个输入输出重定向,管道联接.这里要讲的不是这个而是 我当时想写个程序来演示这些功能:但我发现我的虚拟机中没有装GNU不能用g++命令,然后就惊奇的发现Linux命令行可以直接联网下载安装 ...

  6. ASP.NET MVC 视图层-生成链接相关(Html.ActionLink,Url.Action)

    1. @Html.ActionLink()  参考 也是使用在chtml模板中,返回参数中指定controller.指定action的所生成的超链接标签<a>标签html文本.如果没有指定 ...

  7. 哈雷监控设备的操作及升级NSG9k6G

    哈雷监控设备的操作及升级NSG9k6G 一.下载升级包: http://pan.baidu.com/s/1kTmw9sr 如连接不可以用可以直接私聊我.QQ1841031740 二.升级: 下载完后, ...

  8. Binder学习笔记(六)—— binder服务端是如何组织addService数据的

    在checkService的调查中我们知道客户端向ServiceManager请求服务名,ServiceManager根据服务名遍历本地链表,找到匹配的handle返回给客户端.这个handle显然是 ...

  9. oracle 集群jndi部署方式

    一般部署oracle   jndi的方式: ...jdbc.url=jdbc:oracle:thin:@10.196.20.xx:1521:SID ... 集群部署方式 : ... jdbc.url= ...

  10. Qt(Mac) 进程的启动

    试了半天,终于成功了!!!!(教程都是Windows的) 1.与Windows不一样,Mac的要在了路径前加上open: 2.例 图为把一个按钮与TextEdit程序进程联系,点击后就可以启动Text ...