原文: http://zetcode.com/springboot/responsestatus/

Spring Boot @ResponseStatus教程展示了如何在 Spring 应用中使用@ResponseStatus注解。

Spring 是流行的 Java 应用框架,而 Spring Boot 是 Spring 的演进,可以帮助轻松地创建独立的,生产级的基于 Spring 的应用。

@ResponseStatus

@ResponseStatus用应返回的状态代码和原因消息标记方法或异常类。 调用处理器方法时或抛出指定的异常时,状态代码将应用于 HTTP 响应。 它会覆盖通过其他方式设置的状态信息,例如ResponseEntityredirect:

Spring Boot @ResponseStatus示例

在以下应用中,我们演示@ResponseStatus注解的用法。 该应用模拟用于通过其 ID 检索订单的表单。 尝试查找 ID 大于 500 的订单将引发异常。 由于此异常,将显示一个自定义错误页面。

  1. pom.xml
  2. src
  3. ├── main
  4. ├── java
  5. └── com
  6. └── zetcode
  7. ├── Application.java
  8. ├── controller
  9. └── MyController.java
  10. └── exception
  11. └── OrderNotFoundException.java
  12. └── resources
  13. ├── static
  14. └── index.html
  15. └── templates
  16. └── error.ftl
  17. └── test
  18. └── java

这是 Spring 应用的项目结构。

pom.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
  5. http://maven.apache.org/xsd/maven-4.0.0.xsd">
  6. <modelVersion>4.0.0</modelVersion>
  7. <groupId>com.zetcode</groupId>
  8. <artifactId>springbootresponsestatusex</artifactId>
  9. <version>1.0-SNAPSHOT</version>
  10. <packaging>jar</packaging>
  11. <properties>
  12. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  13. <maven.compiler.source>11</maven.compiler.source>
  14. <maven.compiler.target>11</maven.compiler.target>
  15. </properties>
  16. <parent>
  17. <groupId>org.springframework.boot</groupId>
  18. <artifactId>spring-boot-starter-parent</artifactId>
  19. <version>2.1.1.RELEASE</version>
  20. </parent>
  21. <dependencies>
  22. <dependency>
  23. <groupId>org.springframework.boot</groupId>
  24. <artifactId>spring-boot-starter-web</artifactId>
  25. </dependency>
  26. <dependency>
  27. <groupId>org.springframework.boot</groupId>
  28. <artifactId>spring-boot-starter-freemarker</artifactId>
  29. </dependency>
  30. </dependencies>
  31. <build>
  32. <plugins>
  33. <plugin>
  34. <groupId>org.springframework.boot</groupId>
  35. <artifactId>spring-boot-maven-plugin</artifactId>
  36. </plugin>
  37. </plugins>
  38. </build>
  39. </project>

这是 Maven pom.xml文件。 spring-boot-starter-freemarker是 Freemarker 模板引擎的依赖项; spring-boot-maven-plugin将 Spring 应用打包到可执行的 JAR 或 WAR 归档文件中。

com/zetcode/controller/MyController.java

  1. package com.zetcode.controller;
  2. import com.zetcode.exception.OrderNotFoundException;
  3. import org.springframework.stereotype.Controller;
  4. import org.springframework.web.bind.annotation.PathVariable;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.ResponseBody;
  7. @Controller
  8. public class MyController {
  9. @RequestMapping(value = "/orders/{id}")
  10. @ResponseBody
  11. public String getOrder(@PathVariable("id") long id) {
  12. if (id < 0 || id > 500) {
  13. var message = String.format("Order %d not found", id);
  14. throw new OrderNotFoundException(message);
  15. }
  16. var message = String.format("Returning order %d", id);
  17. return message;
  18. }
  19. }

MyControllergetOrder()方法响应客户端请求。 它使用@PathVariable从路径读取顺序 ID。

  1. if (id < 0 || id > 500) {
  2. var message = String.format("Order %d not found", id);
  3. throw new OrderNotFoundException(message);
  4. }

对于无效订单(id < 0)和大于 500 的订单,我们抛出OrderNotFoundException异常。 这是订单系统的简单模拟。

  1. var message = String.format("Returning order %d", id);

对于其他订单 ID,我们返回一条消息,指示已找到并返回了该订单。

com/zetcode/exception/OrderNotFoundException.java

  1. package com.zetcode.exception;
  2. import org.springframework.http.HttpStatus;
  3. import org.springframework.web.bind.annotation.ResponseStatus;
  4. @ResponseStatus(value = HttpStatus.NOT_FOUND, reason = "No such order")
  5. public class OrderNotFoundException extends RuntimeException {
  6. public OrderNotFoundException(String message) {
  7. super(message);
  8. }
  9. }

我们有一个自定义OrderNotFoundException。 它以@ResponseStatus注解装饰。 该值设置为HttpStatus.NOT_FOUND,并且原因消息显示"No such order"。 此信息将在错误页面中使用。

resources/static/index.html

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Home page</title>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. </head>
  8. <body>
  9. <a href="/orders/505/">Get order with Id 505</a>
  10. </body>
  11. </html>

这是主页。 它包含一个链接,用于查找带有 ID 505 的订单。该文件位于src/main/resources/static目录中。

resources/templates/error.ftl

  1. <html>
  2. <head>
  3. <title>Error page</title>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. </head>
  7. <body>
  8. <div>
  9. <h1>Error occurred</h1>
  10. <p>${status}: ${error} - ${message}</p>
  11. </div>
  12. </body>
  13. </html>

error.ftl是通用错误页面。 这是 Freemarker 模板文件,显示状态,错误和原因消息。 这些值是通过@ResponseStatus设置的。 它位于src/main/resources/templates目录中。

com/zetcode/Application.java

  1. package com.zetcode;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. @SpringBootApplication
  5. public class Application {
  6. public static void main(String[] args) {
  7. SpringApplication.run(Application.class, args);
  8. }
  9. }

Application是设置 Spring Boot 应用的入口。

Spring Boot `@ResponseStatus` - 图1

图:错误页面

在本教程中,我们展示了如何在 Spring 应用中使用@ResponseStatus注解。 您可能也对相关教程感兴趣: Spring Boot ResponseEntity教程Spring Boot @ExceptionHandler教程Java 教程或列出所有 Spring Boot 教程