拨开荷叶行,寻梦已然成。仙女莲花里,翩翩白鹭情。
IMG-LOGO
主页 文章列表 Swagger 中的@ApiOperation 与@ApiResponse

Swagger 中的@ApiOperation 与@ApiResponse

白鹭 - 2022-08-22 2362 0 2

一、概述

在本教程中,我们将讨论Swagger 的@ApiOperation@ApiResponse注释之间的主要区别。

2. Swagger 的描述性文档

当我们创建REST API 时,创建适当的规范也很重要。此外,这样的规范应该是可读的、可理解的,并提供所有必要的信息。

此外,文档应该包含对API 所做的每项更改的描述。手动创建REST API 文档会很累,更重要的是,会很耗时。幸运的是,像Swagger 这样的工具可以帮助我们完成这个过程。

Swagger代表了一组围绕OpenAPI 规范构建的开源工具。它可以帮助我们设计、构建、记录和使用REST API。

Swagger 规范是记录REST API 的标准。使用Swagger 规范,我们可以描述我们的整个API,例如暴露的端点、操作、参数、身份验证方法等。

Swagger 提供了各种注释,可以帮助我们记录REST API。此外,它还提供了@ApiOperation@ApiResponse注释来记录我们REST API 的响应在本教程的其余部分,我们将使用以下控制器类并了解如何使用这些注释:

@RestController
@RequestMapping("/customers")
class CustomerController {
private final CustomerService customerService;
public CustomerController(CustomerService customerService) {
this.customerService = customerService;
}
@GetMapping("/{id}")
public ResponseEntity<CustomerResponse> getCustomer(@PathVariable("id") Long id) {
return ResponseEntity.ok(customerService.getById(id));
}
}

3.@ApiOperation

@ApiOperation注解用于描述单个操作。操作是路径和HTTP 方法的唯一组合。

此外,使用@ApiOperation,我们可以描述成功的REST API 调用的结果。换句话说,我们可以使用这个注解来指定一般的返回类型。

让我们将注解添加到我们的方法中:

@ApiOperation(value = "Gets customer by ID",
response = CustomerResponse.class,
notes = "Customer must exist")
@GetMapping("/{id}")
public ResponseEntity<CustomerResponse> getCustomer(@PathVariable("id") Long id) {
return ResponseEntity.ok(customerService.getById(id));
}

接下来,我们将@ApiOperation中一些最常用的属性。

3.1。value属性

必需的value属性包含操作的汇总字段。简而言之,它提供了操作的简短描述。但是,我们应该将此参数保持在120 个字符以内。

以下是我们在@ApiOperation注释中定义value 属性的方式:

@ApiOperation(value = "Gets customer by ID")

3.2.notes属性

使用notes,我们可以提供有关操作的更多详细信息。例如,我们可以放置一个描述端点限制的文本:

@ApiOperation(value = "Gets customer by ID", notes = "Customer must exist")

3.3.response属性

response属性包含操作的响应类型。此外,设置此属性将覆盖任何自动派生的数据类型。@ApiOperation注解中定义的响应属性应该包含通用响应类型。

让我们创建一个类来代表我们的方法返回的成功响应:

class CustomerResponse {
private Long id;
private String firstName;
private String lastName;
// getters and setters
}

接下来,让我们将response属性添加到我们的注解中:

@ApiOperation(value = "Gets customer by ID",
response = CustomerResponse.class,
notes = "Customer must exist")
@GetMapping("/{id}")
public ResponseEntity<CustomerResponse> getCustomer(@PathVariable("id") Long id) {
return ResponseEntity.ok(customerService.getById(id));
}

3.4.code属性

code 属性表示响应代码的HTTP 状态。HTTP 状态码有多种定义。应该使用其中之一。如果我们不提供,默认值为200。

4.@ApiResponse

使用HTTP 状态代码返回错误是一种常见的做法。我们可以使用@ApiResponse注解来描述操作的具体可能响应。

@ApiOperation注解描述了一个操作和一般返回类型,@ApiResponse注解描述了其余可能的返回码。

此外,注释可以应用于方法级别以及类级别。此外,只有在方法级别尚未定义具有相同代码的@ApiResponse注释时,才会解析放在类级别的注释。换句话说,方法注解优先于类注解。

我们应该在@ApiResponse注释中使用@ApiResponses注释,无论我们有一个还是多个响应。如果我们直接使用这个注解,Swagger 是不会解析的。

让我们在我们的方法上定义@ApiResponses@ApiResponse注释:

@ApiResponses(value = {
@ApiResponse(code = 400, message = "Invalid ID supplied"),
@ApiResponse(code = 404, message = "Customer not found")})
@GetMapping("/{id}")
public ResponseEntity<CustomerResponse> getCustomer(@PathVariable("id") Long id) {
return ResponseEntity.ok(customerService.getById(id));
}

我们也可以使用注解来指定成功响应:

@ApiOperation(value = "Gets customer by ID", notes = "Customer must exist")
@ApiResponses(value = {
@ApiResponse(code = 200, message = "OK", response = CustomerResponse.class),
@ApiResponse(code = 400, message = "Invalid ID supplied"),
@ApiResponse(code = 404, message = "Customer not found"),
@ApiResponse(code = 500, message = "Internal server error", response = ErrorResponse.class)})
@GetMapping("/{id}")
public ResponseEntity<CustomerResponse> getCustomer(@PathVariable("id") Long id) {
return ResponseEntity.ok(customerService.getById(id));
}

如果我们使用@ApiResponse注解指定成功响应,则无需在@ApiOperation注解中定义它。

现在,让我们来@ApiResponse中使用的一些属性。

4.1。codemessage属性

codemessage属性都是@ApiResponse注解中的必需参数。

@ApiOperation注解中的code 属性一样,它应该包含响应的HTTP 状态代码。值得一提的是,我们不能使用相同的code 属性定义多个@ApiResponse

message 属性通常包含与响应一起出现的人类可读消息:

@ApiResponse(code = 400, message = "Invalid ID supplied")

4.2.response属性

有时,端点使用不同的响应类型。例如,我们可以将一种类型用于成功响应,另一种用于错误响应。我们可以通过将响应类与响应代码相关联来使用可选的response属性来描述它们。

首先,让我们定义一个在内部服务器错误的情况下将返回的类:

class ErrorResponse {
private String error;
private String message;
// getters and setters
}

其次,让我们为内部服务器错误添加一个新的@ApiResponse

@ApiResponses(value = {
@ApiResponse(code = 400, message = "Invalid ID supplied"),
@ApiResponse(code = 404, message = "Customer not found"),
@ApiResponse(code = 500, message = "Internal server error", response = ErrorResponse.class)})
@GetMapping("/{id}")
public ResponseEntity<CustomerResponse> getCustomer(@PathVariable("id") Long id) {
return ResponseEntity.ok(customerService.getById(id));
}

5.@ApiOperation@ApiResponse

综上所述,下表显示了@ApiOperation@ApiResponse注解的主要区别:

@ApiOperation@ApiResponse
用于描述操作用于描述操作的可能响应
用于成功响应用于成功和错误响应
只能在方法级别定义可以在方法或类级别上定义
可以直接使用只能在@ApiResponses注解中使用
默认代码属性值为200没有默认代码属性值

六,结论

在本文中,我们了解了@ApiOperation@ApiResponse注解之间的区别。


标签:

0 评论

发表评论

您的电子邮件地址不会被公开。 必填的字段已做标记 *