自定义异常+异常枚举+全局异常处理
- 自定义异常
- 创建一个类继承RuntimeException异常类,通过实现对应的异常方法并且写入自己的异常枚举
- 因为加入的异常枚举有许多种类,因此这里用一个异常枚举的接口类来进行存储
@Data
public class MyException extends RuntimeException{
private IErrorCode errorCode;
public MyException(IErrorCode errorCode) {
this();
this.errorCode = errorCode;
}
public MyException() {
}
public MyException(String message) {
super(message);
}
public MyException(String message, Throwable cause) {
super(message, cause);
}
public MyException(Throwable cause) {
super(cause);
}
public MyException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {
super(message, cause, enableSuppression, writableStackTrace);
}
}
- 自定义异常枚举接口
public interface IErrorCode {
String getCode();
String getErrorMsg();
}
- 自定义接口
@Getter
public enum BusinessErrorCode implements IErrorCode{
MOBILE_EXISTS("10001","电话号码已存在!"),
HOUSE_IN_USE("10002","房间正在使用!"),
HOUSE_NUMBERS_EXISTS("10003","该房号已存在!"),
NO_NUMBERS("10004","房间号为空!"),
BUILDING_NOT_EXISTS("10005","所属楼宇不存在!");
private String code;
private String errorMsg;
BusinessErrorCode(String code, String errorMsg) {
this.code = code;
this.errorMsg = errorMsg;
}
}
- **全局异常处理(使用
@RestControllerAdvice
**注解来创建一个全局异常处理类)
@RestControllerAdvice
public class GlobalExceptionControllerAdvice {
@ExceptionHandler(MyException.class)
public ResponseResult handleException(MyException exception){
IErrorCode errorCode = exception.getErrorCode();
ResponseResult responseResult=ResponseResult.failure(errorCode.getCode(),errorCode.getErrorMsg());
return responseResult;
}
}
@RestControllerAdvice
的主要作用:
-
全局异常处理
:
- 捕捉并处理应用中的异常,确保 RESTful API 返回一致的错误响应格式。
- 通过
@ExceptionHandler
注解定义如何处理不同类型的异常。
-
全局数据绑定和预处理
:
- 为所有控制器提供数据绑定和验证功能,避免在每个控制器中重复定义相同的逻辑。
- 可以通过
@InitBinder
和@ModelAttribute
方法实现。
-
统一的响应处理
:
- 统一处理 API 请求的响应,提供一致的错误消息和状态码。
-
简化代码维护
:
- 将全局的异常处理和数据处理逻辑集中在一个地方,简化应用代码的维护和管理。