java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringMVC HandlerInterceptor拦截器

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

作者:Java法师

本文主要介绍了详解SpringMVC HandlerInterceptor拦截器的使用与参数,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

拦截器概念:

作用:

在这里插入图片描述

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

多拦截器执行顺序:

在这里插入图片描述

责任链模式

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

特征:

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

优势:

弊端:

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

您可能感兴趣的文章:
阅读全文