异常处理

目录

异常处理

处理异常

方案一

方案二

小结


异常处理

  • 程序开发过程中不可避免地会遇见异常现象
  • 在案例功能的实现中我们并没有设置如何对于程序出现异常时如何进行处理
    • 在三层架构中,如果持久层程序运行出现错误,由于我们在三层架构中都没有设置如何处理程序运行异常,那么就会将程序运行的报错信息传递给调用层,比如:Mapper接口类出现问题,那么就会把报错返回给调用的Service类,Service类就会把报错返回给Controller类,最后返回给前端。

    • 具体如下:添加一个已经存在的部门,由于最开始创建depts数据表时,限制了部门名称的唯一性

    • 前端获取的异常信息

处理异常

方案一

  • 在Controller类中的方法中进行try...catch处理
    • 但是控制类中的方法有很多,这样做会加大代码的冗余程度,不推荐

方案二

  • 定义一个全局异常处理器
    • 全局异常处理器,将异常处理过后,将处理结果以标准的响应结果Result返回给前端。

    • 具体代码如下
      *

      java 复制代码
      package com.example.tlias.Exception;
      
      import com.example.tlias.pojo.Result;
      import org.springframework.web.bind.annotation.ExceptionHandler;
      import org.springframework.web.bind.annotation.RestControllerAdvice;
      
      // todo 全局异常处理器
      @RestControllerAdvice //todo = ControllerAdvice + ResponseBody(将方法的返回值转换为JSON格式数据)
      public class GlobalExceptionHandler {
          @ExceptionHandler(Exception.class) // todo 设置要捕获的异常,这里设置捕获所有异常类
          public Result ex(Exception e) {
              e.printStackTrace();//输出异常堆栈信息
              return Result.error("对不起,操作失败,请联系管理员");
          }
      }
    • 运行结果

    • 将设置的Result类的响应结果以JSON数据格式响应给前端

小结

  • 全局异常处理器
    • @RestControllerAdvice
    • @ExceptionHandler //设置捕获异常的类型
相关推荐
麦兜*2 天前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud
麦兜*2 天前
MongoDB 在物联网(IoT)中的应用:海量时序数据处理方案
java·数据库·spring boot·物联网·mongodb·spring
青衫客362 天前
Spring异步编程- 浅谈 Reactor 核心操作符
java·spring·响应式编程
Cyan_RA92 天前
SpringMVC @RequestMapping的使用演示和细节 详解
java·开发语言·后端·spring·mvc·ssm·springmvc
wuxuanok3 天前
SpringBoot -原理篇
java·spring boot·spring
若鱼19193 天前
spring-kafka消费异常处理
spring·kafka
送秋三十五3 天前
spring源码分析————ListableBeanFactory
java·后端·spring
一又四分之一.3 天前
spring、springboot、springCloud
spring boot·spring·spring cloud
float_六七3 天前
Spring事务注解@Transactional核心机制详解
java·后端·spring
Java水解3 天前
从 “Hello AI” 到企业级应用:Spring AI 如何重塑 Java 生态的 AI 开发
后端·spring