全局异常统一处理

本文介绍了如何在Java中实现全局异常处理,包括创建自定义异常类GlobalException,使用@ControllerAdvice注解的GlobalExceptionHandler类来捕获并统一处理各种异常,如自定义异常、空指针异常、参数校验异常和Bean约束异常。
摘要由CSDN通过智能技术生成

全局异常处理的原理:在独立的一个类中,定义一套对各种异常的处理机制,然后用@ControllerAdvice注解该类,统一对不同位置的不同异常进行处理。

实现步骤:

1.封装自定义异常类

public class GlobalException extends RuntimeException {
    private int code;

    public GlobalException() {
    }

    /**
     * MyException
     * @param code 错误代码
     */
    public GlobalException(int code) {
        super("code=" + code);
        this.code = code;
    }

    /**
     * MyException
     * @param message 错误消息
     */
    public GlobalException(String message) {
        super(message);
    }

    /**
     * MyException
     * @param cause 捕获的异常
     */
    public GlobalException(Throwable cause) {
        super(cause);
    }

    /**
     * MyException
     * @param message 错误消息
     * @param cause 捕获的异常
     */
    public GlobalException(String message, Throwable cause) {
        super(message, cause);
    }

    /**
     * MyException
     * @param code 错误代码
     * @param message 错误消息
     */
    public GlobalException(int code, String message) {
        super(message);
        this.code = code;
    }

    public int getCode() {
        return code;
    }

    public void setCode(int code) {
        this.code = code;
    }
}

2.自定义全局异常处理类:


/**
 * 全局异常处理的原理:在独立的一个类中,定义一套对各种异常的处理机制,然后用@ControllerAdvice注解该类,统一对不同位置的不同异常进行处理。
 */

@ControllerAdvice
//@ControllerAdvice 作用为将被@ExceptionHandler修饰的异常处理方法应用与所有的Controller类
public class GlobalExceptionHandler {
    private static Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class);

    @ResponseBody
    //当抛出自定义异常时由该方法捕获处理 添加自定义异常的异常码及信息返回Result对象
    @ExceptionHandler(GlobalException.class)
    public Result MyExceptionHandler(Exception ex) {
        return  Result.error(((GlobalException)ex).getCode(), ex.getMessage());
    }

    @ResponseBody
    //抛出空指针异常时 日志纪录 返回空指针状态码及信息
    @ExceptionHandler(NullPointerException.class)
    public Result nullPointerExceptionHandler(NullPointerException ex) {
        log.error(ex.getMessage(),ex);
        return Result.error(ApiCodeConstant.RESULT_NULLPOINT_EXCEPTION, ex.toString());
    }

    @ResponseBody
    //通用的未知异常处理
    @ExceptionHandler(Exception.class)
    public Result otherExcptionHandler(Exception ex) {
        log.error(ex.getMessage(), ex);
        return  Result.error(ApiCodeConstant.RESULT_OTHER_EXCEPTION, ex.toString());
    }


    /**
     * 控制器参数校验异常
     * @param ex
     * @return
     */
    @ExceptionHandler({MethodArgumentNotValidException.class})
    @ResponseBody
    public Result handleMethodArgumentNotValidException(MethodArgumentNotValidException ex) {
        Map<String, Object> result = new HashMap<>();
        BindingResult bindingResult = ex.getBindingResult();
        StringBuilder sb = new StringBuilder("参数校验异常  ");
        for (FieldError fieldError : bindingResult.getFieldErrors()) {
            sb.append(fieldError.getField()).append(":").append(fieldError.getDefaultMessage()).append(";");
        }
        String msg = sb.toString();
        return Result.error(ApiCodeConstant.PARAMETER_VALIDATION_ERROR,msg);
    }

    /**
     * Bean约束异常
     * @param ex
     * @return
     */
    @ExceptionHandler({ConstraintViolationException.class})
    @ResponseBody
    public Result handleConstraintViolationException(ConstraintViolationException ex) {

        return Result.error(ApiCodeConstant.PARAMETER_VALIDATION_ERROR,ex.getMessage());
    }

}

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,您想了解关于使用 @ExceptionHandler + @ControllerAdvice +枚举实现全局异常统一处理的内容,这是一个常用的方案,可以实现全局异常的捕获和处理,让程序更加健壮和稳定。 @ExceptionHandler注解用于标记一个方法,该方法用于处理指定的异常类型。@ControllerAdvice注解用于标记一个类,该类用于处理全局异常。枚举则可以用于定义异常类型,方便异常处理时的统一管理。 在实现全局异常处理时,我们可以通过 @ExceptionHandler 注解来捕获指定的异常类型,并在方法中进行相应的处理。@ControllerAdvice注解可以让我们在一个类中定义多个 @ExceptionHandler方法,用于处理不同类型的异常。同时,我们也可以使用枚举来定义不同的异常类型,方便管理和调用。 下面是一个简单的示例,演示如何使用 @ExceptionHandler + @ControllerAdvice +枚举实现全局异常统一处理: ```java @ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(value = BusinessException.class) @ResponseBody public ResultVO handleBusinessException(BusinessException e) { return ResultVO.error(e.getCode(), e.getMessage()); } } public enum ExceptionEnum { PARAMETER_ERROR(1001, "参数错误"), DATA_NOT_FOUND(1002, "数据不存在"), SYSTEM_ERROR(5000, "系统错误"); private final int code; private final String message; ExceptionEnum(int code, String message) { this.code = code; this.message = message; } public int getCode() { return code; } public String getMessage() { return message; } } public class BusinessException extends RuntimeException { private final int code; public BusinessException(int code, String message) { super(message); this.code = code; } public BusinessException(ExceptionEnum exceptionEnum) { super(exceptionEnum.getMessage()); this.code = exceptionEnum.getCode(); } public int getCode() { return code; } } ``` 在上面的示例中,GlobalExceptionHandler类标记了@ControllerAdvice注解,用于全局异常处理。其中,handleBusinessException方法用于处理BusinessException异常,返回一个ResultVO对象,其中包含错误码和错误信息。 BusinessException则是一个自定义的异常类,它包含一个code属性和一个message属性,用于表示异常的错误码和错误信息。同时,它还提供了一个构造方法,可以根据ExceptionEnum来构造一个BusinessException对象。 ExceptionEnum则是一个枚举类,包含了不同的异常类型,每个异常类型都有一个对应的错误码和错误信息。 在实际开发中,我们可以根据实际需求来定义不同的异常类型和错误码,以便更好地管理和调用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值