Swagger/OpenAPI - 使用 $ref 传递可重用的定义参数

标签 swagger swagger-2.0 openapi

假设我有一个像 limit 这样的参数。这个被到处使用,如果我需要更新它,就必须到处更改它,这是一件痛苦的事情:

parameters:
    - name: limit
      in: query
      description: Limits the number of returned results
      required: false
      type: number
      format: int32

我可以使用 $ref 在其他地方定义它并使其可重用吗?我遇到了this ticket这表明有人想要更改或改进功能,但我无法判断它今天是否已经存在?

最佳答案

此功能已存在于 Swagger 2.0 中。链接的票证讨论了它的一些特定机制,这不会影响此功能的功能。

在顶级对象(称为 Swagger 对象)中,有一个 parameters 属性,您可以在其中定义可重用的参数。您可以为参数指定任何名称,并从路径/特定操作中引用它。顶级参数只是定义,不会自动应用于规范中的所有操作。

您可以在这里找到一个示例 - https://github.com/swagger-api/swagger-spec/blob/master/fixtures/v2.0/json/resources/reusableParameters.json - 即使有限制参数。

就您而言,您需要这样做:

# define a path with parameter reference
/path:
   get:
      parameters:
         - $ref: "#/parameters/limitParam"
         - $ref: "#/parameters/offsetParam"

# define reusable parameters:
parameters:
   limitParam:
      name: limit
      in: query
      description: Limits the number of returned results
      required: false
      type: integer
      format: int32
   offsetParam:
      name: offset
      in: query
      description: Offset from which start returned results
      required: false
      type: integer
      format: int32

关于Swagger/OpenAPI - 使用 $ref 传递可重用的定义参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27005105/

相关文章:

swagger - 如何在 Swagger 规范中使用 'Authorization: Bearer <token>'

Swagger: "equivalent path already exists"尽管参数不同

swagger - 如何在 Swagger 规范中定义不同示例的数组?

node.js - 将 swagger 添加到我的 Nodejs Restify 项目

Django rest swagger 嵌套序列化程序在示例 UI 中显示数组列表

spring-boot - OpenApi 使用 JSON 发送 MultipartFile 请求获取 'application/octet-stream' 错误不支持

openapi - Quarkus Openapi 扩展 : Get the generated openapi yml file at build time

swagger - Swagger ,是否有推荐的方法来记录具有长度限制的数字字段?

node.js - 处理使用 1 时调用的多个 Swagger SecurityHandler 定义?

c# - 在 swagger C# .net 核心中使用 FormData 发送字符串数组?