• SpringMVC (3)—拦截器


    目录

    一、SpringMVC拦截器

    1.1 拦截器(interceptor)的作用

    1.2 拦截器和过滤器区别

    1.3 拦截器快速入门

    1.4 多拦截器操作

    1.5 拦截器方法说明

    二、SpringMVC异常处理机制

    2.1 异常处理的思路

    2.2 异常处理的两种方式

    2.2.1 简单异常处理器 SimpleMappingExceptionResolver

    2.2.2 自定义异常处理步骤


    一、SpringMVC拦截器

    1.1 拦截器(interceptor)的作用

    SpringMVC的拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理后处理

    将拦截器按一定的顺序联结成一条链,这条链被称为拦截器链(Interceptor Chain)。在访问被拦截的方法或字段时,拦截器链中的拦截器就会按其之前定义的顺序被调用。拦截器也是AOP思想的具体实现。

    1.2 拦截器和过滤器区别

    区别过滤器(Filter)拦截器(Interceptor)
    使用范围是 servlet 规范中的一部分,任何 Java Web 工程都可以使用是 SpringMVC 框架自己的,只有使用了 SpringMVC 框架的工程才能用
    拦截范围在 url-pattern 中配置了/*之后, 可以对所有要访问的资源拦截中配置了/**之后,也可以多所有资源进行拦截,但是可以通过标签排除不需要拦截的资源

    1.3 拦截器快速入门

    自定义拦截器三个步骤

    ①创建拦截器类实现HandlerInterceptor接口

    ②配置拦截器

    ③测试拦截器的拦截效果

    代码实现

    ① 创建拦截器类实现HandlerInterceptor接口

    1. public class MyInterceptor1 implements HandlerInterceptor {
    2. @Override
    3. //在目标方法执行之前 执行
    4. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    5. System.out.println("preHandle...");
    6. String param = request.getParameter("param");
    7. if ("yes".equals(param)){
    8. return true;
    9. }else {
    10. request.getRequestDispatcher("/error.jsp").forward(request,response);
    11. return false;
    12. }
    13. //return true; //返回true表示放行,返回false表示不放行
    14. }
    15. @Override
    16. //在目标方法执行之后,视图对象返回之前 执行
    17. public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
    18. modelAndView.addObject("name","我被改了~");
    19. System.out.println("postHandle...");
    20. }
    21. @Override
    22. //在流程都执行完毕后 执行
    23. public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
    24. System.out.println("afterCompletion...");
    25. }
    26. }

    ② 配置拦截器

    1. <mvc:interceptors>
    2. <mvc:interceptor>
    3. <mvc:mapping path="/**"/>
    4. <bean class="com.learn.interceptor.MyInterceptor1"/>
    5. mvc:interceptor>
    6. mvc:interceptors>

    ③ 测试拦截器的拦截效果(编写目标方法)

    1. @Controller
    2. public class TargetController {
    3. @RequestMapping("/target")
    4. public ModelAndView show(){
    5. System.out.println("目标资源执行...");
    6. ModelAndView modelAndView = new ModelAndView();
    7. modelAndView.addObject("name","gugumao");
    8. modelAndView.setViewName("index");
    9. return modelAndView;
    10. }
    11. }

    这里url不带param参数或者param参数不为yes的话会跳转到error.jsp页面中

     控制台打印顺序如下:

    1.4 多拦截器操作

    同上,再编写一个MyHandlerInterceptor2操作,测试执行顺序如下:

    1.5 拦截器方法说明

    方法名说明
    preHandle()方法将在请求处理之前进行调用,该方法的返回值是布尔值Boolean类型的, 当它返回为 false 时,表示请求结束,后续的Interceptor 和Controller 都不会再执行;当返回值为true 时就会继续调用下一个Interceptor 的 preHandle 方法
    postHandle()该方法是在当前请求进行处理之后被调用,前提是 preHandle 方法的返回值为 true 时才能被调用,且它会在DispatcherServlet 进行视图返回渲染之前被调用,所以我们可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作
    afterCompletion()该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行,前提是 preHandle 方法的返回值为true时才能被调用

    二、SpringMVC异常处理机制

    2.1 异常处理的思路

    系统中异常包括两类:预期异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发、测试等手段减少运行时异常的发生

    系统的DAO、Service、Controller出现都通过throws Exception向上抛出,最后由SpringMVC前端控制器交由异常处理器进行异常处理,如下图:

    2.2 异常处理的两种方式

    • 使用SpringMVC提供的简单异常处理器 SimpleMappingExceptionResolver
    • 实现Spring的异常处理接口 HandlerExceptionRosolver 自定义自己的异常处理器

    2.2.1 简单异常处理器 SimpleMappingExceptionResolver

    SpringMVC已经定义好了该类型转换器,在使用时可以根据项目情况进行相应异常与视图的映射配置

    1. <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
    2. <property name="defaultErrorView" value="error"/>
    3. <property name="exceptionMappings">
    4. <map>
    5. <entry key="java.lang.ClassCastException" value="error1"/>
    6. <entry key="com.learn.exception.MyException" value="error2"/>
    7. map>
    8. property>
    9. bean>

    2.2.2 自定义异常处理步骤

    ①创建异常处理器实现HandlerExceptionResolver接口

    ②配置异常处理器

    ③编写异常页面

    ④测试异常跳转

    代码实现

    创建异常处理器类实现HandlerExceptionResolver

    1. public class MyExceptionResolver implements HandlerExceptionResolver {
    2. /*
    3. 参数Exception:异常对象
    4. 返回值ModelAndView:跳转到错误视图信息
    5. */
    6. public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
    7. //处理异常的代码实现
    8. //创建ModelAndView对象
    9. ModelAndView modelAndView = new ModelAndView();
    10. if(e instanceof MyException){
    11. modelAndView.addObject("info","自定义异常");
    12. }else if(e instanceof ClassCastException){
    13. modelAndView.addObject("info","类转换异常");
    14. }
    15. modelAndView.setViewName("error");
    16. return modelAndView;
    17. }
    18. }

    配置异常处理器

    1. <bean class="com.learn.resolver.MyExceptionResolver"/>

    编写异常页面

    1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    2. <html>
    3. <head>
    4. <title>Titletitle>
    5. head>
    6. <body>
    7. <h1>通用的错误提示页面h1>
    8. <h1>${info}h1>
    9. body>
    10. html>

    测试异常跳转

    1. @Controller
    2. public class DemoController {
    3. @Autowired
    4. private DemoService demoService;
    5. @RequestMapping(value = "/show")
    6. public String show() throws FileNotFoundException, MyException {
    7. System.out.println("show running......");
    8. //demoService.show1();
    9. //demoService.show2();
    10. //demoService.show3();
    11. //demoService.show4();
    12. demoService.show5();
    13. return "index";
    14. }
    15. }

  • 相关阅读:
    Python 增量更新/打包解决方案 -- Depsland
    YOLO性能指标
    switch case 语句(详细)
    【科普分享】linux服务器文件挂载技术介绍——mount
    python web开发过程
    OpenGeometry 开源社区特聘子虔科技云CAD专家 共建云几何内核
    C# Winform应用程序简介
    Vue基础知识测试
    MySQL索引事务
    线上kafka消息堆积,consumer掉线,怎么办?
  • 原文地址:https://blog.csdn.net/weixin_61843013/article/details/126000870