Spring - 全局异常处理器的使用

30 篇文章 3 订阅

一. 自定义异常和全局处理

1.1 自定义异常类

首先我们定义一个接口,规范了自定义异常的几种函数:

public interface CommonError {
    int getErrorCode();
    String getErrorMsg();
    CommonError setErrMsg(String errMsg);
}

然后我们可以自定义一个枚举异常类,定义了对应的异常原因和code代码:

public enum EmBusinessError implements CommonError {
    // 通用错误类型 1000x
    UNKNOWN_ERROR(10000, "未知错误"),
    // 类型为数据库操作异常 2000x
    DATA_ERROR(20000, "数据库操作失败"),
    DATA_INSERT_ERROR(20001, "数据库插入异常"),
    DATA_DELETE_ERROR(20002, "数据库删除异常"),
    DATA_UPDATE_ERROR(20003, "数据库更新异常"),
    DATA_SELECT_ERROR(20004, "数据库查询异常"),
    // 业务失败 3000x
    USER_NOT_EXIST(30001, "用户不存在"),
    // 验权失败 4000x
    USER_AUTH_ERROR(40001, "验权失败"),
    USER_PERMISSION_ERROR(40002, "权限不足"),
    SHIRO_USER_AUTH_ERROR(40003, "shiro认证失败"),
    ;

    EmBusinessError(int errCode, String errMsg) {
        this.errCode = errCode;
        this.errMsg = errMsg;
    }

    private int errCode;
    private String errMsg;


    @Override
    public int getErrorCode() {
        return errCode;
    }

    @Override
    public String getErrorMsg() {
        return errMsg;
    }

    @Override
    public CommonError setErrMsg(String errMsg) {
        this.errMsg = errMsg;
        return this;
    }
}

接下来就可以自定义异常了:

public class BusinessException extends RuntimeException implements CommonError {

    private CommonError commonError;

    // 直接接受EmBusinessError的传参用于构造业务异常
    public BusinessException(CommonError commonError) {
        super();
        this.commonError = commonError;
    }

    // 接受自定义errMsg的方式构造业务异常
    public BusinessException(CommonError commonError, String errorMsg) {
        super();
        this.commonError = commonError;
        this.commonError.setErrMsg(errorMsg);
    }

    @Override
    public int getErrorCode() {
        return this.commonError.getErrorCode();
    }

    @Override
    public String getErrorMsg() {
        return this.commonError.getErrorMsg();
    }

    @Override
    public CommonError setErrMsg(String errMsg) {
        this.commonError.setErrMsg(errMsg);
        return this;
    }
}

1.2 统一风格的返回格式

我们自定义一个CommonReturnType类,无论是正常的请求还是异常的捕获,我们都用这个类来完成构建Response对象。

public class CommonReturnType {

    // 返回请求处理结果
    private String status;
    // 返回数据
    private Object data;

    public static CommonReturnType creat(Object result) {
        return CommonReturnType.creat(result, "success");
    }

    public static CommonReturnType fail(CommonError error) {
        return fail(error.getErrorCode(), error.getErrorMsg());
    }

    public static CommonReturnType fail(CommonError error, String errorMsg) {
        return fail(error.getErrorCode(), errorMsg);
    }

    public static CommonReturnType fail(Integer errorCode, String errorMsg) {
        CommonReturnType type = new CommonReturnType();
        Map<String, Object> responseData = new HashMap<>();
        responseData.put("errorCode", errorCode);
        responseData.put("errorMsg", errorMsg);
        type.setStatus("fail");
        type.setData(responseData);
        return type;
    }

    public static CommonReturnType creat(Object result, String status) {
        CommonReturnType type = new CommonReturnType();
        type.setData(result);
        type.setStatus(status);

        return type;
    }

    public String getStatus() {
        return status;
    }

    public void setStatus(String status) {
        this.status = status;
    }

    public Object getData() {
        return data;
    }

    public void setData(Object data) {
        this.data = data;
    }

1.3 全局处理

我们自定义一个ExceptionController,加上@RestControllerAdvice注解。

@RestControllerAdvice
@Slf4j
public class ExceptionController {
    // 捕获自定义异常
    @ExceptionHandler(BusinessException.class)
    public CommonReturnType businessException(BusinessException e) {
        return CommonReturnType.fail(e);
    }

    // 捕捉其他所有异常
    @ExceptionHandler(Exception.class)
    public CommonReturnType globalException(Exception e) {
        return CommonReturnType.fail(EmBusinessError.UNKNOWN_ERROR.getErrorCode(),e.getMessage());
    }
}

那么我们在业务代码上,如果想抛出自定义异常,就可以:

public void process(){
	// 业务处理
	if(xxx){
		throw new BusinessException(EmBusinessError.USER_NOT_EXIST);
	}
}

如果是正常的接口返回:

@PostMapping("/login")
public CommonReturnType login() {
    Map<String, String> map = new HashMap<>();
    map.put("msg", "Success");
	User user = new User();
    user.setPhone("123456");
    map.put("data", user);
    return CommonReturnType.creat(map);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在Spring Cloud中,我们可以通过自定义全局异常处理来处理应用程序中的所有异常。以下是实现全局异常处理的步骤: 1. 创建一个全局异常处理类,该类应该实现Spring的ErrorController接口。 2. 在处理类中,使用@RequestMapping注解来定义处理所有错误请求的路由。 3. 在路由方法中,获取请求中的异常信息,并根据异常类型返回相应的错误响应。 4. 在应用程序的配置文件中,将Spring的默认错误处理禁用,并将全局异常处理类注册为错误处理。 以下是一个简单的全局异常处理示例: ``` @RestController @ControllerAdvice public class GlobalExceptionHandler implements ErrorController { @RequestMapping("/error") public ResponseEntity<ErrorResponse> handleAllExceptions(HttpServletRequest request) { ErrorResponse errorResponse = new ErrorResponse(); errorResponse.setErrorCode(HttpStatus.INTERNAL_SERVER_ERROR.value()); errorResponse.setErrorMessage("An error occurred during the request."); errorResponse.setRequestedURI(request.getRequestURI()); return new ResponseEntity<>(errorResponse, HttpStatus.INTERNAL_SERVER_ERROR); } @Override public String getErrorPath() { return "/error"; } } ``` 在上面的代码中,我们实现了Spring的ErrorController接口,并使用@ControllerAdvice注解来指定该类为全局异常处理。在handleAllExceptions方法中,我们获取请求中的异常信息,并根据异常类型返回相应的错误响应。最后,我们将该类注册为错误处理,并将Spring的默认错误处理禁用。 ### 回答2: Spring Cloud是一个用于构建微服务架构的框架,它提供了许多功能和组件来简化微服务的开发和管理。其中之一就是全局异常处理全局异常处理是一个用于捕获和处理应用程序中发生的异常的组件。在微服务架构中,由于各个服务之间的调用和交互,很可能会出现许多不同种类的异常,例如网络异常、数据库异常、业务异常等。而全局异常处理的作用就是捕获这些异常,并根据具体情况进行统一处理。 使用Spring Cloud的全局异常处理,可以帮助我们实现以下功能: 1. 统一异常处理:无论是哪个服务发生了异常,全局异常处理都能捕获并进行处理,避免异常导致系统崩溃或无响应。 2. 异常信息返回:全局异常处理可以将捕获到的异常信息封装成特定的响应格式,方便客户端或其他服务进行处理。 3. 异常分类处理:根据异常的类型和来源,全局异常处理可以将异常分类处理,例如数据库异常可以跳转到指定的错误页面,业务异常可以返回特定的错误码等。 4. 日志记录:全局异常处理可以将捕获到的异常信息进行日志记录,方便开发人员进行问题排查和分析。 总之,Spring Cloud的全局异常处理是一个非常实用的组件,能够帮助我们捕获和处理微服务架构中的异常,并保证系统的稳定性和可靠性。通过合理配置和使用全局异常处理,我们可以更好地管理和维护我们的微服务应用程序。 ### 回答3: Spring Cloud全局异常处理是用来统一处理系统中出现的异常情况。在微服务架构中,由于系统由多个服务组成,每个服务都可能出现异常,如果每个服务都单独处理异常,会造成代码冗余和维护困难。因此,引入全局异常处理可以统一处理所有服务的异常,提高代码的可维护性和可读性。 Spring Cloud全局异常处理的工作原理如下:首先,在服务启动时,通过配置文件或代码,将异常处理注册到Spring中。当服务中发生异常时,Spring会捕获到异常,并根据异常类型和处理的配置,将异常交给对应的处理进行处理。处理可以通过捕获异常的类型来判断异常的种类,并根据不同的异常类型进行不同的处理,例如返回给前端用户友好的错误信息、记录异常日志等。 使用全局异常处理的好处如下:首先,可以减少代码的冗余,不需要在每个服务中都编写相同的异常处理代码;其次,可以提高代码的可读性,将异常处理的逻辑集中在一个地方,便于理解和维护;还可以提高系统的容错性和稳定性,可以捕获并处理各种异常情况,避免系统因为异常导致崩溃或无法正常运行。 总结而言,Spring Cloud全局异常处理是一个集中处理系统中异常情况的机制,能够统一处理微服务架构中各个服务的异常,提高代码的可维护性和系统的容错性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Zong_0915

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值