经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » Java相关 » Spring » 查看文章
详解SpringMVC?HandlerInterceptor拦截器的使用与参数
来源:jb51  时间:2022/1/18 17:31:49  对本文有异议

拦截器概念:

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

作用:

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

在这里插入图片描述

拦截器VS过滤器

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

在这里插入图片描述

拦截器执行流程:

自定义拦截器开发过程:

实现HandlerInterceptor接口

  1. //自定义拦截器需要实现HandleInterceptor接口
  2. public class MyInterceptor implements HandlerInterceptor {
  3.  
  4. //前置处理方法:原始方法之前执行
  5. @Override
  6. public boolean preHandle(HttpServletRequest request, //请求对象
  7. HttpServletResponse response, //响应对象
  8. Object handler) // 被调用的处理器对象,本质是一个方法对象,对反射中的Method对象进行了再包装,对方法进行封装加强,操作原始对象,
  9. throws Exception {
  10. System.out.println("前置运行");
  11. //返回值为false将拦截原始处理器的运行,也就是是否放行,如果是false后面的代码不会运行,如果是true就继续执行下面的代码
  12. //如果配置多拦截器,返回值为false将终止当前拦截器后面配置的拦截器的运行
  13. return true;
  14. }
  15.  
  16.  
  17. //后置处理方法:原始方法运行后运行,如果原始方法被拦截,则不执行
  18. @Override
  19. public void postHandle(HttpServletRequest request,
  20. HttpServletResponse response,
  21. Object handler,
  22. ModelAndView modelAndView) // 如果处理器执行完成具有返回结果,可以读取到对应数据与页面信息进行调整
  23. throws Exception {
  24. System.out.println("后置运行");
  25. }
  26.  
  27.  
  28. // 完成处理方法:拦截器最后执行的方法,无论原始方法是否执行
  29. @Override
  30. public void afterCompletion(HttpServletRequest request,
  31. HttpServletResponse response,
  32. Object handler,
  33. Exception ex) // 如果处理器执行过程中出现异常对象,可以针对异常情况进行单独处理
  34. throws Exception {
  35. System.out.println("完成运行");
  36. }
  37.  
  38. //三个方法的运行顺序为 preHandle -> postHandle -> afterCompletion
  39. //如果preHandle返回值为false,三个方法仅运行preHandle
  40. }

拦截器配置项:

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

多拦截器配置:

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

  1. <mvc:interceptors>
  2. <mvc:interceptor>
  3. <mvc:mapping path="/showPage"/>
  4. <bean class="com.itzhuzhu.interceptor.MyInterceptor"/>
  5. </mvc:interceptor>
  6. </mvc:interceptors>
  7. <mvc:interceptors>
  8. <mvc:interceptor>
  9. <mvc:mapping path="/showPage"/>
  10. <bean class="com.itzhuzhu.interceptor.MyInterceptor2"/>
  11. </mvc:interceptor>
  12. </mvc:interceptors>
  13.  
  14. <mvc:interceptors>
  15. <mvc:interceptor>
  16. <mvc:mapping path="/showPage"/>
  17. <bean class="com.itzhuzhu.interceptor.MyInterceptor3"/>
  18. </mvc:interceptor>
  19. </mvc:interceptors>

多拦截器执行顺序:

在这里插入图片描述

责任链模式

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

特征:

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

优势:

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

弊端:

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

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号