文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

六个Spring Boot处理异常的小技巧

2024-11-30 07:35

关注

在Spring框架中,@ControllerAdvice是全局异常处理机制,用于集中处理应用程序中发生的异常。

当任何控制器方法(例如REST端点)抛出异常时,该异常会被@ControllerAdvice注解的类捕获。

@ControllerAdvice类中的@ExceptionHandler方法用于处理特定类型的异常,并返回适当的响应。

本文我们通过一个实际场景的例子来详细说明,在Spring Boot应用程序中处理产品相关的自定义异常并进行全局处理的情况。

步骤:

1. 创建自定义的ProductNotFoundException:

在这一步中,我们创建一个自定义异常类ProductNotFoundException,它继承自RuntimeException。这个自定义异常用于表示系统中找不到产品的情况。通过创建自定义异常,我们可以提供更具体的错误信息。

public class ProductNotFoundException extends RuntimeException {
 public ProductNotFoundException(Long productId) {
 super(“Product not found with ID: “ + productId);
 }
}

解释:

2. 创建产品服务(Product Service):

在这步,我们创建一个ProductService类,负责获取产品信息。如果找不到产品,会抛出ProductNotFoundException。

@Service
public class ProductService {

    public Product getProductById(Long productId) {
        // 模拟获取产品的逻辑
        Product product = getProductFromDatabase(productId);
        
        if (product == null) {
            throw new ProductNotFoundException(productId);
        }
        
        return product;
    }

    // 模拟从数据库获取产品的方法
    private Product getProductFromDatabase(Long productId) {
        // 在这里实现您的数据库逻辑
        // 如果找不到产品,则返回null
        return null;
    }
}

解释:

3. 创建全局异常处理器(Global Exception Handler):

这一步涉及使用@ControllerAdvice创建一个全局异常处理器。该处理器负责全局捕获ProductNotFoundException,并返回自定义错误响应。

@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(ProductNotFoundException.class)
    public ResponseEntity handleProductNotFoundException(ProductNotFoundException ex) {
        ErrorResponse errorResponse = new ErrorResponse(HttpStatus.NOT_FOUND.value(), ex.getMessage());
        return ResponseEntity.status(HttpStatus.NOT_FOUND).body(errorResponse);
    }
}

解释:

4. 创建自定义错误响应类(Custom Error Response Class):

我们定义一个自定义的错误响应类ErrorResponse,以便在应用程序中统一结构化错误消息。

public class ErrorResponse {
    private int statusCode;
    private String message;

    public ErrorResponse(int statusCode, String message) {
        this.statusCode = statusCode;
        this.message = message;
    }
    // Getter方法
}

解释:

5. 产品控制器(Controller):

在这一步中,我们创建一个控制器ProductController,负责处理根据产品ID获取产品的请求。

@RestController
@RequestMapping("/api/products")
public class ProductController {

    @Autowired
    private ProductService productService;

    @GetMapping("/{productId}")
    public ResponseEntity getProduct(@PathVariable Long productId) {
        Product product = productService.getProductById(productId);
        return ResponseEntity.ok(product);
    }
}

解释:

6. 测试异常处理:

为了测试异常处理,发送GET请求来获取在系统中不存在的产品信息。这将触发ProductNotFoundException,并由全局异常处理器返回一个JSON格式的错误消息。

curl -X GET http://localhost:8080/api/products/123

响应:

{
    "statusCode": 404,
    "message": "Product not found with ID: 123"
}

解释:

顺序流程图

从控制器到使用@ControllerAdvice进行错误处理的Spring应用程序的流程顺序图:

(1) 控制器层:

客户端(例如Web浏览器或REST客户端)向Spring应用程序发出请求,通常是向公开的HTTP端点发送请求。

(2) 控制器方法执行:

Spring MVC框架根据请求映射注解(如@GetMapping或@PostMapping)将传入的请求路由到适当的控制器方法。

控制器方法执行并执行其业务逻辑。

(3) 异常发生:

在执行控制器方法的过程中,由于各种原因可能会抛出异常。这可能是由于业务逻辑错误、验证失败或任何其他意外问题。

4 异常传播:

一旦在控制器方法内部抛出异常,它就会开始沿着调用堆栈向上传播。

(55) @ControllerAdvice类:

异常向上传播,直到达到使用@ControllerAdvice注解的全局异常处理器类为止。

(6) @ExceptionHandler方法:

在@ControllerAdvice类中,定义了一个或多个@ExceptionHandler方法来处理特定类型的异常。

(7) 匹配异常处理器:

Spring框架根据方法的参数类型识别出适当的@ExceptionHandler方法来处理特定的异常类型。

(8) 异常处理:

匹配的@ExceptionHandler方法执行以处理异常。

此方法可以执行诸如记录错误、构建错误响应或执行任何其他自定义操作的任务。

(9) 生成响应:

@ExceptionHandler方法通常生成一个错误响应,可以是JSON响应、HTML页面或任何其他响应格式。

(10) 响应发送给客户端:

由@ExceptionHandler方法生成的错误响应发送回原始请求的客户端。

(11) 客户端接收错误响应:

客户端接收错误响应,并根据需要处理错误信息。例如,它可以向用户显示错误消息或以编程方式处理错误。

来源:Java学研大本营内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯