目录
统一异常处理的原因
在我们写代码的时候,因为各种场景需要进行各种校验,我们就可能会进行多种响应,多种异常返回,会出现的情况就是,满屏幕的try cache,可读性不高,所以需要进行一个统一异常处理
如果进行统一异常处理
个人觉得,进行统一异常处理的步骤,分为这么几部分
1、编写统一异常处理类与方法
@ControllerAdvice
public class ExceptionAdvice {
@ExceptionHandler(MyException.class)
public ResponseEntity<MyRsp> doRsp (MyException e) {
return ResponseEntity.status(200).body(new MyRsp(e.getStatus(), e.getMessage()));
}
}
@Data
@AllArgsConstructor
@NoArgsConstructor
public class MyRsp {
private String statusCode;
private String statusDesc;
}
这里出现了两个注解,@ControllerAdvice和@ExceptionHandler
第一个注解的作用就是,只要你加了@Controller的类,抛出了异常,就会走这个添加了@ControllerAdvice的类
第二个注解的作用,就是当前类发生了异常,就会走加了@ExceptionHandler的注解的方法
2、编写自定义异常类
@Data
@AllArgsConstructor
public class MyException extends RuntimeException{
private String status;
private String message;
public MyException(ExceptionEnu e) {
this.status = e.getCode();
this.message = e.getMessage();
}
}
3、定义异常枚举类
@Getter
public enum ExceptionEnu {
SUCCESS("1", "成功"),
FAILD("2", "失败");
private String code;
private String message;
ExceptionEnu(String code, String message) {
this.code = code;
this.message = message;
}
}
4、抛出指定异常
@RestController
public class OneController {
@GetMapping("/doCheck")
public String doCheck (int age) {
if (age > 1) {
throw new MyException(ExceptionEnu.SUCCESS);
} else {
throw new MyException(ExceptionEnu.FAILD);
}
}
}
小提醒
当然,不是所有的情况都要进行统一异常处理,本人遇到过的好些个场景,都是不可以进行统一异常处理的,必须try cache
比如:调用一个别的服务,如果调用成功了,那就走这个流程,如果调用失败了,那就走那个流程,这个就必须用 try cache了,不能做统一异常处理,你要是做了统一异常处理,好家伙,直接这个流程结束了,这不就没得玩了
要不要做统一异常处理,这个需要结合实际业务来判断,这里不过多讨论