全局异常处理
后台开发中,我们通常看到报错时返回的是一些500、400等错误代码,但是有时需要返回一些易读、友好的错误信息,或者要和其他开发伙伴统一起来,这时便可以通过自定义的方式。
我们使用 int a = 10/0来测试。
- 配置全局异常处理类GlobalExceptionHandler
@ControllerAdvice
// @RestControllerAdvice //可以省去@ResponseBody
public class GlobalExceptionHandler {
@ExceptionHandler(Exception.class) //作用: 表明处理的是哪些异常
@ResponseBody //controller用的是@RestController,即使用json格式。
public Result error(Exception e){
e.printStackTrace();
return Result.fail(); //Result类是自己封装的返回数据格式。FAIL(201, "失败")
}
}
配置前返回的异常信息:
进行配置后的返回信息:
自定义异常处理
- 自定义全局异常类
import com.atguigu.yygh.result.ResultCodeEnum;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
/**
* 自定义全局异常类
*
* @author qy
*/
@Data
@ApiModel(value = "自定义全局异常类")
public class HospitalException extends RuntimeException {
@ApiModelProperty(value = "异常状态码")
private Integer code;
/**
* 通过状态码和错误消息创建异常对象
* @param message
* @param code
*/
public HospitalException(String message, Integer code) {
super(message);
this.code = code;
}
/**
* 接收枚举类型对象
* @param resultCodeEnum
*/
public HospitalException(ResultCodeEnum resultCodeEnum) {
super(resultCodeEnum.getMessage());
this.code = resultCodeEnum.getCode();
}
@Override
public String toString() {
return "HospitalException{" +
"code=" + code +
", message=" + this.getMessage() +
'}';
}
}
- 在配置类GlobalExceptionHandler中进行配置
@ExceptionHandler(HospitalException.class)
@ResponseBody
public Result error(HospitalException e){
e.printStackTrace();
return Result.fail();
}
- 模拟异常进行测试
// 根据id查询
@ApiOperation("根据id查询信息")
@GetMapping("getHospSet/{id}")
public Result getHospSet(@PathVariable Long id) {
// 模拟异常
try {
int a = 10/0;
} catch (Exception e) {
throw new HospitalException("失败啦!",201);
}
HospitalSet hospitalSet = hospitalSetService.getById(id);
return Result.ok(hospitalSet);
}