1.注解
@ExceptionHandler:用于指定异常处理方法。当与@RestControllerAdvice配合使用时,用于全局处理控制器里的异常。
2.配置类
@RestControllerAdvice
@Slf4j
public class GlobalExceptionHandler {
@ExceptionHandler(Exception.class)
public Result handleException(Exception e) {
log.error("系统异常", e);
return ResultGenerator.genResult(ResultCode.E_500.getCode(), e.getMessage(), null);
}
@ExceptionHandler(NewRuntimException.class)
public Result handleException(NewRuntimException e) {
log.error("请求异常被程序拦截", e);
return e.getErrorCode() == 0 ? ResultGenerator.genResult(ResultCode.E_500.getCode(), e.getMessage(), null) : ResultGenerator.genResult(e.getErrorCode(), e.getMessage(), null);
}
}
3.使用
当项目在运行时抛出NewRuntimException或者我们手动抛出NewRuntimException后,GlobalExceptionHandler 会自动捕获到该异常,并按照配置类中声明的返回体响应给前端
if (true){
throw new NewRuntimException(500,"测试异常");
}
4.自定义异常类
新建一个配置类,并继承RunRuntimeException即可,可以添加有参构造方法,用来声明异常code
4.1配置类实例
public class NewRuntimException extends RuntimeException {
private static final long serialVersionUID = 1L;
private int errorCode;
public NewRuntimException(String msg) {
super(msg);
}
public NewRuntimException(int errorCode, String msg) {
super(msg);
//自定义错误码
this.setErrorCode(errorCode);
}
public int getErrorCode() {
return errorCode;
}
public void setErrorCode(int errorCode) {
this.errorCode = errorCode;
}
}
4.2使用
public boolean indexExist(String index) {
if (true){
throw new NewRuntimException(ResultCode.E_400.getCode(),"该索引不存在,请检查参数");
}
}