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

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. 关于PDF的一些书籍

    PDF Explained: The ISO Standard for Document Exchange https://ssearch.oreilly.com/?q=PDF+

  2. R: 自动计算代码运行时间

    ################################################### 问题:代码运行时间   18.4.25 怎么计算代码的运行时间? 解决方案: ptm = pro ...

  3. head first 设计模式 观察者模式

    Head first 设计模式:定义了对象之间的一对多依赖,这样一来,当一个对象改变状态时,它的所有依赖者都会受到通知并自动更新.   让主题与观察者之间松耦合 大话设计模式:定义了一种一对多的依赖关 ...

  4. Entity Framework Tutorial Basics(7):DBContext

    DBContext: As you have seen in the previous Create Entity Data Model section, EDM generates the Scho ...

  5. Entity Framework Tutorial Basics(3):Entity Framework Architecture

    Entity Framework Architecture The following figure shows the overall architecture of the Entity Fram ...

  6. C++文件流打开标识符.RP

    ofstream流,以ios::app打开(或者“ios::app|ios::out”),如果没有文件,那么生成空文件:如果有文件,那么在文件尾追加.以ios::app|ios::in打开,不管有没有 ...

  7. C 标签使用

    JSTL 核心标签库标签共有13个,功能上分为4类: 1.表达式控制标签:out.set.remove.catch 2.流程控制标签:if.choose.when.otherwise 3.循环标签:f ...

  8. JavsScript中JSON相关

    1.JSON.parse(jsonString) JSON.parse(jsonString):将一个JSON格式的字符串字面值,转换成JSON对象,它的逆运算方法是JSON.stringify(ob ...

  9. Python学习第三方库Requests: 让 HTTP 服务人类

    转自官方文档:http://cn.python-requests.org/zh_CN/latest/ 快速上手 http://cn.python-requests.org/zh_CN/latest/u ...

  10. Glib之主事件循环

    介绍 GLib和GTK+应用的主事件循环管理着所有事件源.这些事件的来源有很多种比如文件描述符(文件.管道或套接字)或超时.新类型的事件源可以通过g_source_attach()函数添加. 为了让多 ...