浅谈之SpringMVC拦截器

SpringMVC拦截器

可能大家之前有接触过过滤器,同样是按照顺序被调用,可是有什么区别呢,其实有几分相似又有几分区别。

区别:

  • 过滤器:是servlet规范中的一部分,如何java web工程都可以使用。
  • 拦截器:是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能用。
  • 过滤器:在url-pattern中配置了 /* 之后,可以拦截所有要访问的资源。
  • 拦截器:它只是会拦截访问的控制器方法,如果访问的是jsp、html、css、image或者js是不会进行拦截的。它是AOP思想的具体应用。

实现步骤

  1. 编写拦截器类,实现HandInterceptor接口
  2. 配置拦截器

配置springmvc.xml中的拦截器

    <!--配置拦截器-->
    <mvc:interceptors>
        <mvc:interceptor>
            <!--要拦截的具体方法-->
            <mvc:mapping path="/uer/*"/>
            <!--不要拦截的具体方法-->
<!--            <mvc:exclude-mapping path=""/>-->
            <!--配置拦截器对象-->
            <bean class="cn.itcast.interceptor.MyIntercepor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

MyInterceptor1

public class MyInterceptor1 implements HandlerInterceptor {
    /**
     * 预处理,controller方法执行前,可以用来判断是否登录
     * return true 放行,执行下一个拦截器,如果没有,执行controller中的方法
     * return false不放行
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("MyInterceptor执行了。。。前111");
//        request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request,response);
        return true;
    }

    /**
     * 后处理方法,controller方法执行后,success.jsp执行之前,执行一些逻辑代码
     * @param request
     * @param response
     * @param handler
     * @param modelAndView
     * @throws Exception
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("MyInterceptor执行了。。。后111");
//        request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request,response);
    }

    /**
     * success.jsp执行之后,该方法执行,可以用来释放资源
     * @param request
     * @param response
     * @param handler
     * @param ex
     * @throws Exception
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("MyInterceptor执行了。。。最后111");
    }
}

controllor中的testInterception

@RequestMapping("testInterceptor")

    public String testInterceptor(){
        System.out.println("testInterceptor执行了。。。");
        return "success";
    }

success.jsp

<body>
<h3>执行成功</h3>
<% System.out.println("success.jsp执行了....");%>
</body>

运行结果控制台输出情况:
在这里插入图片描述

配置多个拦截器执行顺序

springmvc.xml中配置多个拦截器

<!--配置拦截器-->
    <mvc:interceptors>
        <mvc:interceptor>
            <!--要拦截的具体方法-->
            <mvc:mapping path="/user/*"/>
            <!--不要拦截的具体方法-->
<!--            <mvc:exclude-mapping path=""/>-->
            <!--配置拦截器对象-->
            <bean class="cn.itcast.interceptor.MyInterceptor1"></bean>
        </mvc:interceptor>
            <!-- 配置第二个拦截器-->
        <mvc:interceptor>
            <!--要拦截的具体方法-->
            <mvc:mapping path="/user/*"/>
            <!--不要拦截的具体方法-->
            <!--            <mvc:exclude-mapping path=""/>-->
            <!--配置拦截器对象-->
            <bean class="cn.itcast.interceptor.MyInterceptor2"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

执行流程分析

  • 首先执行拦截器1,拦截器1放行->执行拦截器2,拦截器2放行->执行controllor的testInterceptor方法。
  • 然后会返回,先走拦截器2的后处理->拦截器1的后处理->执行success.jsp
  • 最后执行拦截器2的最后的方法->拦截器1的最后方法。
    在这里插入图片描述
    执行结果:

在这里插入图片描述

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下 4载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值