欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

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

时间:2022-12-19 13:57:13|栏目:JAVA代码|点击:

拦截器概念:

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

作用:

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

在这里插入图片描述

拦截器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
}

拦截器配置项:

<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>

多拦截器配置:

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

    <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>

多拦截器执行顺序:

在这里插入图片描述

责任链模式

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

特征:

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

优势:

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

弊端:

  • 链路过长时,处理效率低下
  • 可能存在节点上的循环引用现象,造成死循环,导致系统崩溃

上一篇:SpringBoot整合Redis实现访问量统计的示例代码

栏    目:JAVA代码

下一篇:Spring Boot深入排查 java.lang.ArrayStoreException异常

本文标题:详解SpringMVC HandlerInterceptor拦截器的使用与参数

本文地址:http://www.codeinn.net/misctech/221741.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有