SpringBoot接口 - 怎么处理Controller异常

为什么要优雅的处理异常

如果我们不统一的处理异常,经常会在controller层有大量的异常处理的代码, 比如:

@Slf4j@Api(value = "User Interfaces", tags = "User Interfaces")@RestController@RequestMapping("/user")public class UserController {    /**     * http://localhost:8080/user/add .     *     * @param userParam user param     * @return user     */    @ApiOperation("Add User")    @ApiImplicitParam(name = "userParam", type = "body", dataTypeClass = UserParam.class, required = true)    @PostMapping("add")    public ResponseEntity<String> add(@Valid @RequestBody UserParam userParam) {        // 每个接口充斥着大量的异常处理        try {            // do something        } catch(Exception e) {            return ResponseEntity.fail("error");        }        return ResponseEntity.ok("success");    }}

那怎么实现统一的异常处理,特别是结合参数校验等封装?

实现案例

简单展示通过@ControllerAdvice进行统一异常处理。

@ControllerAdvice异常统一处理

对于400参数错误异常

/** * Global exception handler. * * @author pdai */@Slf4j@RestControllerAdvicepublic class GlobalExceptionHandler {    /**     * exception handler for bad request.     *     * @param e     *            exception     * @return ResponseResult     */    @ResponseBody    @ResponseStatus(code = HttpStatus.BAD_REQUEST)    @ExceptionHandler(value = { BindException.class, ValidationException.class, MethodArgumentNotValidException.class })    public ResponseResult<ExceptionData> handleParameterVerificationException(@NonNull Exception e) {        ExceptionData.ExceptionDataBuilder exceptionDataBuilder = ExceptionData.builder();        log.warn("Exception: {}", e.getMessage());        if (e instanceof BindException) {            BindingResult bindingResult = ((MethodArgumentNotValidException) e).getBindingResult();            bindingResult.getAllErrors().stream().map(DefaultMessageSourceResolvable::getDefaultMessage)                    .forEach(exceptionDataBuilder::error);        } else if (e instanceof ConstraintViolationException) {            if (e.getMessage() != null) {                exceptionDataBuilder.error(e.getMessage());            }        } else {            exceptionDataBuilder.error("invalid parameter");        }        return ResponseResultEntity.fail(exceptionDataBuilder.build(), "invalid parameter");    }}

对于自定义异常

/** * handle business exception. * * @param businessException *            business exception * @return ResponseResult */@ResponseBody@ExceptionHandler(BusinessException.class)public ResponseResult<BusinessException> processBusiness
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值