欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-03-04 14:44:45
目录拦截器概念:拦截器vs过滤器自定义拦截器开发过程:拦截器配置项:多拦截器配置:拦截器概念:拦截器( interceptor)是一种动态拦截方法调用的机制,请求处理过程解析核心原理: aop思想拦截...

拦截器概念:

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

作用:

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

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

拦截器vs过滤器

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

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

拦截器执行流程:

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

自定义拦截器开发过程:

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

多拦截器执行顺序:

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

责任链模式

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

特征:

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

优势:

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

弊端:

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

 到此这篇关于详解springmvc handlerinterceptor拦截器的使用与参数的文章就介绍到这了,更多相关springmvc handlerinterceptor拦截器内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!