当前位置:   article > 正文

SpringMVC-HandlerInterceptor拦截器的使用与参数详解_springmvc handlerinterceptor

springmvc handlerinterceptor

拦截器概念:

  • 拦截器( Interceptor)是一种动态拦截方法调用的机制,请求处理过程解析
  • 核心原理: AOP思想
  • 拦截器链:多个拦截器按照一定的顺序,对原始被调用功能进行增强

作用:

  1. 在指定的方法调用前后执行预先设定后的的代码
  2. 阻止原始方法的执行

在这里插入图片描述

拦截器VS过滤器

  • 归属不同: 过滤器属于Servlet技术, 拦截器属于SpringMVC技术
  • 拦截内容不同: 过滤器对所有访问进行增强, 拦截器仅针对SpringMVC的访问进行增强

在这里插入图片描述

拦截器执行流程:

自定义拦截器开发过程:

实现HandlerInterceptor接口

//自定义拦截器需要实现HandleInterceptor接口
public class MyInterceptor implements HandlerInterceptor {

    //前置处理方法:原始方法之前执行
    @Override
    public boolean preHandle(HttpServletRequest request, //请求对象
                             HttpServletResponse response, //响应对象
                             Object handler)   // 被调用的处理器对象,本质是一个方法对象,对反射中的Method对象进行了再包装,对方法进行封装加强,操作原始对象,
                                       throws Exception {
        System.out.println("前置运行");
        //返回值为false将拦截原始处理器的运行,也就是是否放行,如果是false后面的代码不会运行,如果是true就继续执行下面的代码
        //如果配置多拦截器,返回值为false将终止当前拦截器后面配置的拦截器的运行
        return true;
    }


    //后置处理方法:原始方法运行后运行,如果原始方法被拦截,则不执行
    @Override
    public void postHandle(HttpServletRequest request,
                           HttpServletResponse response,
                           Object handler,
                           ModelAndView modelAndView) // 如果处理器执行完成具有返回结果,可以读取到对应数据与页面信息进行调整
                           throws Exception {
        System.out.println("后置运行");
    }


    // 完成处理方法:拦截器最后执行的方法,无论原始方法是否执行
    @Override
    public void afterCompletion(HttpServletRequest request,
                                HttpServletResponse response,
                                Object handler,
                                Exception ex) // 如果处理器执行过程中出现异常对象,可以针对异常情况进行单独处理
                                throws Exception {
        System.out.println("完成运行");
    }

    //三个方法的运行顺序为    preHandle -> postHandle -> afterCompletion
    //如果preHandle返回值为false,三个方法仅运行preHandle
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40

拦截器配置项:

<mvc:interceptors>
    <!--开启具体的拦截器的使用,可以配置多个-->
    <mvc:interceptor>
        <!--设置拦截器的拦截路径,支持*通配-->
        <!--/**         表示拦截所有映射-->
        <!--/*          表示拦截所有/开头的映射-->
        <!--/user/*     表示拦截所有/user/开头的映射-->
        <!--/user/add*  表示拦截所有/user/开头,且具体映射名称以add开头的映射-->
        <!--/user/*All  表示拦截所有/user/开头,且具体映射名称以All结尾的映射-->
        <mvc:mapping path="/*"/>
        <mvc:mapping path="/**"/>
        <mvc:mapping path="/handleRun*"/>
        <!--设置拦截排除的路径,配置/**或/*,达到快速配置的目的-->
        <mvc:exclude-mapping path="/b*"/>
        <!--指定具体的拦截器类 bean标签(ref标签)只能配置一个  
        ref:引用bean的 -->
        <bean class="com.itzhuzhu.interceptor.MyInterceptor"/>
    </mvc:interceptor>
</mvc:interceptors>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

多拦截器配置:

运行顺序:配置在前,则执行在前。

    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/showPage"/>
            <bean class="com.itzhuzhu.interceptor.MyInterceptor"/>
        </mvc:interceptor>
    </mvc:interceptors>
    
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/showPage"/>
            <bean class="com.itzhuzhu.interceptor.MyInterceptor2"/>
        </mvc:interceptor>
    </mvc:interceptors>

    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/showPage"/>
            <bean class="com.itzhuzhu.interceptor.MyInterceptor3"/>
        </mvc:interceptor>
    </mvc:interceptors>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
多拦截器执行顺序:

在这里插入图片描述

责任链模式

责任链模式是一种行为模式

特征:

沿着一条预先设定的任务链顺序执行,每个节点具有独立的工作任务

优势:

  • 独立性:只关注当前节点的任务,对其他任务直接放行到下一节点
  • 隔离性:具备链式传递特征,无需知晓整体链路结构,只需等待请求到达后进行处理即可
  • 灵活性:可以任意修改链路结构动态新增或删减整体链路责任
  • 解耦:将动态任务与原始任务解耦

弊端:

  • 链路过长时,处理效率低下
  • 可能存在节点上的循环引用现象,造成死循环,导致系统崩溃
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/972894
推荐阅读
相关标签
  

闽ICP备14008679号