> 文章列表 > 【SpringMVC】5—异常映射

【SpringMVC】5—异常映射

【SpringMVC】5—异常映射

⭐⭐⭐⭐⭐⭐
Github主页👉https://github.com/A-BigTree
笔记链接👉https://github.com/A-BigTree/Code_Learning
⭐⭐⭐⭐⭐⭐

如果可以,麻烦各位看官顺手点个star~😊

如果文章对你有所帮助,可以点赞👍收藏⭐支持一下博主~😆


文章目录

  • 5 异常映射
    • 5.1 概念
      • 5.1.1 微观
      • 5.1.2 宏观
    • 5.2 异常映射的好处
    • 5.3 基于XML的异常映射
      • 5.3.1 配置
      • 5.3.2 异常范围
    • 5.4 基于注解的异常映射
      • 5.4.1 创建异常处理类并加入IOC容器
      • 5.4.2 给异常处理类标记注解
      • 5.4.3 声明处理异常的方法
    • 5.5 区分请求类型
      • 5.5.1 分析
      • 5.5.2 判断方法

5 异常映射

5.1 概念

5.1.1 微观

将异常类型和某个具体的视图关联起来,建立映射关系。好处是可以通过SpringMVC框架来帮助我们管理异常。

  • 声明式管理异常:在配置文件中指定异常类型和视图之间的对应关系。在配置文件或注解类中统一管理。
  • 编程式管理异常:需要我们自己手动 try ... catch ... 捕获异常,然后再手动跳转到某个页面。

5.1.2 宏观

整个项目从架构这个层面设计的异常处理的统一机制和规范。

一个项目中会包含很多个模块,各个模块需要分工完成。如果张三负责的模块按照A方案处理异常,李四负责的模块按照B方案处理异常……各个模块处理异常的思路、代码、命名细节都不一样,那么就会让整个项目非常混乱。

5.2 异常映射的好处

  • 使用声明式代替编程式来实现异常管理
    • 让异常控制和核心业务解耦,二者各自维护,结构性更好
  • 整个项目层面使用同一套规则来管理异常
    • 整个项目代码风格更加统一、简洁
    • 便于团队成员之间的彼此协作

5.3 基于XML的异常映射

5.3.1 配置

SpringMVC 会根据异常映射信息,在捕获到指定异常对象后,将异常对象存入请求域,然后转发到和异常类型关联的视图。

<bean id="exceptionResolver"class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"><!-- 配置异常映射关系 --><property name="exceptionMappings"><props><!-- key属性:指定异常类型 --><!-- 文本标签体:和异常类型对应的逻辑视图 --><prop key="java.lang.ArithmeticException">error-arith</prop></props></property><!-- 使用 exceptionAttribute 属性配置将异常对象存入请求域时使用的属性名 --><!-- 这个属性名默认是exception --><property name="exceptionAttribute" value="atguiguException"/>
</bean>

5.3.2 异常范围

如果在配置文件中,发现有多个匹配的异常类型,那么 SpringMVC 会采纳范围上最接近的异常映射关系。

<prop key="java.lang.ArithmeticException">error-arith</prop>
<prop key="java.lang.RuntimeException">error-runtime</prop>

5.4 基于注解的异常映射

5.4.1 创建异常处理类并加入IOC容器

<context:component-scan base-package="com.atguigu.mvc.handler,com.atguigu.mvc.exception"/>

5.4.2 给异常处理类标记注解

// 异常处理器类需要使用 @ControllerAdvice 注解标记
@ControllerAdvice
public class MyExceptionHandler {}

5.4.3 声明处理异常的方法

// @ExceptionHandler注解:标记异常处理方法
// value属性:指定匹配的异常类型
// 异常类型的形参:SpringMVC 捕获到的异常对象
@ExceptionHandler(value = NullPointerException.class)
public String resolveNullPointerException(Exception e, Model model) {// 我们可以自己手动将异常对象存入模型model.addAttribute("atguiguException", e);// 返回逻辑视图名称return "error-nullpointer";
}

当同一个异常类型在基于XML和注解的配置中都能够找到对应的映射,那么以注解为准。

5.5 区分请求类型

5.5.1 分析

在这里插入图片描述

5.5.2 判断方法

查看请求消息头中是否包含 Ajax 请求独有的特征:

  • Accept请求消息头:包含application/json
  • X-Requested-With请求消息头:包含XMLHttpRequest
@ExceptionHandler(value = Exception.class)
public String resolveException(Exception e, HttpServletRequest request, HttpServletResponse response) throws IOException {// 调用工具方法判断当前请求是否是 Ajax 请求boolean judgeResult = MVCUtil.judgeRequestType(request);if (judgeResult) {// 对 Ajax 请求返回字符串作为响应体String message = e.getMessage();response.setContentType("text/html;charset=UTF-8");response.getWriter().write(message);// 上面已经使用原生 response 对象返回了响应,这里就不返回视图名称了return null;}// 对普通请求返回逻辑视图名称return "error-exception";
}