SpringBoot 如何进行 统一异常处理

在Spring Boot中,可以通过自定义异常处理器来实现统一异常处理。异常处理器能够捕获应用程序中抛出的各种异常,并提供相应的错误处理和响应。

Spring Boot提供了@ControllerAdvice注解,它可以将一个类标记为全局异常处理器。全局异常处理器能够拦截所有Controller层抛出的异常,提供统一的处理逻辑。

下面是实现统一异常处理的详细步骤:

一、创建自定义异常类

首先,你需要根据自己的需求创建自定义的异常类。可以继承现有的异常类,比如RuntimeException,或者创建自己的异常类。自定义异常类应该包含错误码和错误消息等必要的信息。

复制代码
public class CustomException extends RuntimeException {
    private int errorCode;
    private String errorMessage;
    
    // 构造方法
    
    // getter和setter方法
}

二、创建全局异常处理器类

使用@ControllerAdvice注解来标记全局异常处理器类。然后,在类中定义异常处理方法,用@ExceptionHandler注解来指定需要处理的异常类型。

复制代码
@ControllerAdvice
public class GlobalExceptionHandler {
    
    @ExceptionHandler(CustomException.class)
    public ResponseEntity<ErrorResponse> handleCustomException(CustomException ex) {
        ErrorResponse errorResponse = new ErrorResponse(ex.getErrorCode(), ex.getErrorMessage());
        return new ResponseEntity<>(errorResponse, HttpStatus.INTERNAL_SERVER_ERROR);
    }
    
    // 其他异常处理方法
    
    @ExceptionHandler(Exception.class)
    public ResponseEntity<ErrorResponse> handleException(Exception ex) {
        ErrorResponse errorResponse = new ErrorResponse(HttpStatus.INTERNAL_SERVER_ERROR.value(), ex.getMessage());
        return new ResponseEntity<>(errorResponse, HttpStatus.INTERNAL_SERVER_ERROR);
    }
}

在上述代码中,handleCustomException方法用于处理CustomException异常,handleException方法用于处理其他未被明确定义处理方法的异常。这些异常处理方法可以返回自定义的错误响应对象。

三、创建错误响应类

创建一个错误响应类,用于封装错误码和错误消息等信息。

复制代码
public class ErrorResponse {
    private int errorCode;
    private String errorMessage;
    
    // 构造方法
    
    // getter和setter方法
}

通过以上步骤,你就完成了统一异常处理的实现。当应用程序中抛出异常时,Spring Boot会自动调用对应的异常处理方法,并根据处理方法返回的错误响应进行响应。

需要注意的是,在实际应用中,你可以根据业务需求自定义更多的异常类和异常处理方法,以处理不同类型的异常情况。此外,你还可以添加其他的注解或逻辑来扩展和优化全局异常处理的功能。

四、小结

相关推荐
9523611 小时前
MyBatis
后端·spring·mybatis
FQNmxDG4S12 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
虹科网络安全13 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje14 小时前
Java语法进阶
java·开发语言·jvm
uzong14 小时前
9 种 RAG 架构,每位 AI 开发者必学:完整实战指南
后端
HackTorjan14 小时前
深度神经网络的反向传播与梯度优化原理
人工智能·spring boot·神经网络·机器学习·dnn
rKWP8gKv714 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫14 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_4352879214 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本14 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka