详解如何在SpringBoot项目中使用全局异常处理
目录
- 1. 创建自定义异常
- 2.创建全局异常处理器
- 3.创建测试控制器
在完整的项目开发中,异常的出现几乎是无法避免的;如果凡是有可能出现异常的地方,我们都手动的使用try-catch将其捕获的话,虽然也能达到处理异常的效果,但是这样做会使得代码显得十分臃肿并且后期不好维护,也不利于多人系统开发。
在Spring Boot中提供了统一处理异常的方法,SpringBoot中有一个ControllerAdvice的注解,使用该注解表示开启了全局异常的捕获,我们只需在自定义一个方法使用ExceptionHandler注解然后定义捕获异常的类型即可对这些捕获的异常进行统一的处理。接下来就用一个小demo来演示一下全局异常处理的方法。
1. 创建自定义异常
接着上一篇在Spring Boot项目中使用统一返回结果一文中,继续添加全局异常处理部分。
NotLoginException.java
@Data @NoArgsConstructor @AllArgsConstructor @ToString public class NotLoginException extends RuntimeException{ private Integer errorCode; private String message; }
2.创建全局异常处理器
定义全局异常处理器,用来捕获项目中抛出的自定义异常和普通异常,然后按照统一的数据格式返回给前端。在项目中不管是返回失败结果,还是返回成功结果,我们都统一返回数据的格式。
MyExceptionHandler.java
@ControllerAdvice public class MyExceptionHandler { /** * 捕获我们自定义的异常 * @param notLoginException * @return */ @ExceptionHandler(NotLoginException.class) @ResponseBody public Result notLoginExceptionHandler(NotLoginException notLoginException){ return ResultGenerator.genErrorResult(notLoginException.getErrorCode(), notLoginException.getMessage()); } /** * 捕获其他异常 * @param exception * @return */ @ExceptionHandler(Exception.class) @ResponseBody public Result otherException(Exception exception){ return ResultGenerator.genErrorResult(Constants.RESULT_CODE_SERVER_ERROR, exception.getMessage()); } // 可以定义区分更细粒度的异常,然后在此处进行捕获 }
3.创建测试控制器
ExceptionController.java
@Controller public class ExceptionController { @GetMapping("/notLoginException/{id}") @ResponseBody public Result notLoginException(@PathVariable("id") Integer id){ if(id != null && id == 1){ // 抛出一个自定义的异常 throw new NotLoginException(Constants.RESULT_CODE_BAD_REQUEST, "没有登陆"); // 这里一般会定一个枚举,定义每一个状态码对应的信息 } return ResultGenerator.genSuccessResult(); } @GetMapping("/exception") @ResponseBody public Result exception(){ int num = 1 / 0; return ResultGenerator.genSuccessResult(); } }
测试自定义异常,先正常给参数,接着给错误参数,让其抛出异常。
测试其他异常。
在Spring Boot项目中全局异常处理的方法大致相同,只需要前期制定好需要处理那些异常,然后定义好枚举来映射异常信息,采用上述方法统一处理即可。
以上就是详解如何在SpringBoot项目中使用全局异常处理的详细内容,更多关于SpringBoot全局异常处理的资料请关注我们其它相关文章!
赞 (0)