统一异常处理

文章展示了如何在Java中实现全局异常处理,包括对BadSqlGrammarException、RuntimeException和其他异常的捕获和处理。同时,文章介绍了创建自定义异常BusinessException,该异常继承自RuntimeException,并定义了异常枚举GlobalErrorEnum用于存储错误代码和消息。
摘要由CSDN通过智能技术生成

1.全局异常处理类别实现异常捕获GlobalExceptionHandler

@Slf4j
@RestControllerAdvice
public class GlobalExceptionHandler {
 
 
    /**
     * sql异常
     *
     * @param e
     * @return
     */
    @ExceptionHandler(BadSqlGrammarException.class)
    public AjaxResult badSqlException(BadSqlGrammarException e) {
        log.error("异常信息:{}", e);
        return AjaxResult.fail(GlobalErrorEnum.BAD_SQL, e.getMessage());
    }
 
    /**
     * 自定义异常统一捕获
     *
     * @param e
     * @return
     */
    @ExceptionHandler(RuntimeException.class)
    public AjaxResult runtimeException(RuntimeException e) {
        log.error("异常信息:{}", e);
        int code = GlobalErrorEnum.RUN_TIME_ERROR.getCode();
        try {
            Method method = e.getClass().getMethod("getCode");
            code = (int) method.invoke(e, new Object[]{});
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        }
        return AjaxResult.fail(code, e.getMessage());
    }
 
 
    /**
     * 其他异常
     *
     * @param e
     * @return
     */
    @ExceptionHandler(Exception.class)
    public AjaxResult customException(Exception e) {
        log.error("异常信息:{}", e);
        if (e instanceof NullPointerException) {
            return AjaxResult.fail(GlobalErrorEnum.PARAMETER_NOT_NULL.getCode(), GlobalErrorEnum.PARAMETER_NOT_NULL.getMsg(), stackTrace(e));
        } else if (e instanceof OauthException) {
            return AjaxResult.fail(((OauthException) e).getCode(), ((OauthException) e).getMessage(), stackTrace(e));
        } else if (e instanceof MethodArgumentNotValidException) {
            MethodArgumentNotValidException exception = (MethodArgumentNotValidException) e;
            List<ObjectError> errorsList = exception.getBindingResult().getAllErrors();
            StringJoiner sj = new StringJoiner(";");
            for (ObjectError error : errorsList) {
                sj.add(error.getDefaultMessage());
            }
            return AjaxResult.fail(GlobalErrorEnum.PARAMETER_NOTVALID_EXCEPTION.getCode(), sj.toString(), stackTrace(e));
        }
        return AjaxResult.fail(GlobalErrorEnum.SYS_ERROR.getCode(), GlobalErrorEnum.SYS_ERROR.getMsg(), stackTrace(e));
    }
 
 
    private String stackTrace(Throwable throwable) {
        if (throwable == null || throwable.getStackTrace() == null) {
            return null;
        }
        StackTraceElement stackTraceElement = throwable.getStackTrace()[0];
        return stackTraceElement.getClassName() + ":" + stackTraceElement.getLineNumber();
    }
 
}

2.创建自定义异常,示例如下

        2.1 定义自定义异常,并继承RuntimeException,必须要定义code字段     

@Data
public class BusinessException extends RuntimeException {
    private int code;
 
    public BusinessException(IErrorCode errorCode) {
        super(errorCode.msg());
        this.code = errorCode.code();
    }
}
        2.2 定义异常枚举
@Getter
public enum GlobalErrorEnum implements IErrorCode {
 
    SYS_ERROR(1001, "系统异常!!"),
    LACK_OF_PARAMETER(1002, "缺少参数异常!!"),
    PARAMETER_NOT_NULL(1003, "参数不能为空异常!!"),
    BAD_SQL(1027, "sql语法错误!!"),
    ;
    private int code;
    private String msg;
 
 
    GlobalErrorEnum(int code, String msg) {
        this.code = code;
        this.msg = msg;
    }
 
    @Override
    public int code() {
        return code;
    }
 
    @Override
    public String msg() {
        return msg;
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot提供了一种简单而强大的方式来处理应用程序中的异常,即统一异常处理。通过统一异常处理,我们可以捕获处理应用程序中的所有异常,并返回自定义的错误响应。 在Spring Boot中,我们可以使用@ControllerAdvice注解来定义一个全局的异常处理类。这个类可以包含多个异常处理方法,每个方法对应一个具体的异常类型。当应用程序中抛出对应的异常时,Spring Boot会自动调用相应的异常处理方法进行处理。 下面是一个简单的示例代码,演示了如何使用@ControllerAdvice来实现统一异常处理: ```java @ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(Exception.class) public ResponseEntity<ErrorResponse> handleException(Exception ex) { ErrorResponse errorResponse = new ErrorResponse(); errorResponse.setMessage("Internal Server Error"); errorResponse.setStatus(HttpStatus.INTERNAL_SERVER_ERROR.value()); return new ResponseEntity<>(errorResponse, HttpStatus.INTERNAL_SERVER_ERROR); } @ExceptionHandler(UserNotFoundException.class) public ResponseEntity<ErrorResponse> handleUserNotFoundException(UserNotFoundException ex) { ErrorResponse errorResponse = new ErrorResponse(); errorResponse.setMessage("User Not Found"); errorResponse.setStatus(HttpStatus.NOT_FOUND.value()); return new ResponseEntity<>(errorResponse, HttpStatus.NOT_FOUND); } // 其他异常处理方法... } ``` 在上面的代码中,我们定义了两个异常处理方法:handleException和handleUserNotFoundException。handleException方法用于处理所有未被其他异常处理方法捕获异常,而handleUserNotFoundException方法用于处理UserNotFoundException异常。 在每个异常处理方法中,我们可以根据具体的业务需求,创建一个自定义的错误响应对象,并将其封装在ResponseEntity中返回给客户端。这样,无论是哪种异常,都可以得到统一的错误响应。 需要注意的是,为了使统一异常处理生效,我们还需要在应用程序的配置类上添加@EnableWebMvc注解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值