异常处理

目录

异常处理

处理异常

方案一

方案二

小结


异常处理

  • 程序开发过程中不可避免地会遇见异常现象
  • 在案例功能的实现中我们并没有设置如何对于程序出现异常时如何进行处理
    • 在三层架构中,如果持久层程序运行出现错误,由于我们在三层架构中都没有设置如何处理程序运行异常,那么就会将程序运行的报错信息传递给调用层,比如: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 分钟前
Spring Task 定时任务
java·前端·spring
爱的叹息20 分钟前
Java 连接 Redis 的驱动(Jedis、Lettuce、Redisson、Spring Data Redis)分类及对比
java·redis·spring
松韬1 小时前
Spring + Redisson:从 0 到 1 搭建高可用分布式缓存系统
java·redis·分布式·spring·缓存
天上掉下来个程小白1 小时前
Redis-14.在Java中操作Redis-Spring Data Redis使用方式-操作列表类型的数据
java·redis·spring·springboot·苍穹外卖
汤姆大聪明2 小时前
Redisson 操作 Redis Stream 消息队列详解及实战案例
redis·spring·缓存·maven
正经摸鱼4 小时前
classpath与classpath*实现逻辑
后端·spring
良枫4 小时前
Spring Security认证授权深度解析
spring boot·spring
BeerBear5 小时前
记一次Kill <Pid> Java进程无法退出的问题处理
java·后端·spring
用键盘当武器的秋刀鱼6 小时前
springBoot统一响应类型3.5.3版本
java·spring boot·spring
栗筝i6 小时前
Spring 核心技术解析【纯干货版】- XVII:Spring 网络模块 Spring-WebFlux 模块精讲
java·网络·spring