3

我正在 Spring Boot 中开发一个应用程序。我想知道处理异常的最佳方法是什么。所以以下是我的代码,

ExceptionHandler.java 我正在使用@ControllerAdvice. 什么是最好用的?@ControllerAdvice还是@RestControllerAdvice

@ControllerAdvice
public class ExceptionHandler {

    @ExceptionHandler(NotFoundException.class)
    public ResponseEntity<ErrorResponse> notFound(NotFoundException notFoundException) {
        ErrorResponse errorResponse = new ErrorResponse(HttpStatus.NOT_FOUND, notFoundException.getMessage());
        return new ResponseEntity<ErrorResponse>(errorResponse, HttpStatus.NOT_FOUND);
    }
}

并实现服务层@Service如下,

@Override
public User update(User newUser) throws NotFoundException {
    Optional<User> user = userRepository.findById(newUser.getId());

    if (!user.isPresent()) throw new NotFoundException("Record Not Found!");

    return userRepository.save(newUser);
}

Controller.java代码如下,

@PutMapping
public User update(@RequestBody User user) {
    User updatedUser = userService.update(user);

    if (updatedUser == null) throw new SomeOtherException("Exception while Updating!");
    
    return updatedUser;
}

所以我的问题是:

上述方法不好吗?可以在服务层抛出异常并且它会自动捕获@controlleradvice吗?还是只需要在控制器中抛出?我正在寻找处理异常的最佳实践。

4

2 回答 2

3

您使用的方式非常好。

因为@ControllerAdvice/@RestControllerAdvice用于在整个控制器 [流] 中全局处理异常。

你也可以在@Service layerel 中抛出异常。[那是同一件事] ControllerAdvice 会抓住它。

您可以按照自己的方式自定义异常。

于 2020-11-10T07:27:30.813 回答
0

我也喜欢你的方法。也许你也想看看 Lombok 和@SneakyThrows:我发现在方法上抛出 XYZ 是不必要的,但最终你还是在全局范围内处理它们。

于 2020-11-11T07:36:50.923 回答