首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何通过代码指定Swagger规范扩展?

如何通过代码指定Swagger规范扩展?
EN

Stack Overflow用户
提问于 2021-08-27 14:09:57
回答 1查看 95关注 0票数 0

我正在尝试将自定义属性添加到生成的swagger.json的info部分。我发现很多文章都在讨论如何在json中添加属性,方法是在它们前面加上"x-“。(例如:https://swagger.io/specification/#specification-extensions)

但是,我找不到任何说明如何通过C#代码做到这一点的东西。(当前使用的是.NET 5)

我们目前将标准属性设置如下:

代码语言:javascript
复制
options.SwaggerDoc(Swagger.Version, new OpenApiInfo
{
  Title = "Service Api",
  Version = Swagger.Version,
  Description = "This describes the routes associated with the Service Api."
});

为了测试这一点,我尝试像这样扩展OpenApiInfo:

代码语言:javascript
复制
public class CustomInfo : OpenApiInfo
{
  [JsonPropertyName("x-test")]
  public String Test;
}

然后像这样修改SwaggerDoc:

代码语言:javascript
复制
options.SwaggerDoc(Swagger.Version, new CustomInfo
{
  Title = "Service Api",
  Version = Swagger.Version,
  Description = "This describes the routes associated with the Service Api.",
  Test = "New Value"
});

这不起作用。如何在接口信息中添加自定义属性(规范扩展)?

EN

回答 1

Stack Overflow用户

发布于 2021-08-27 15:28:48

我发现您可以轻松地将自定义属性(规范扩展)添加到OpenApiInfo的扩展属性中。您不需要为字典的值创建自己的实现IOpenApiExtension的类。

代码语言:javascript
复制
options.SwaggerDoc(Swagger.Version, new OpenApiInfo
{
  Title = "Service Api",
  Version = Swagger.Version,
  Description = "This describes the routes associated with the Service Api.",
  Extensions = new Dictionary<string, IOpenApiExtension>
  {
    { "x-company", new OpenApiString("Company Name") },
    { "x-contact", new OpenApiString("contact@email.com") }
  }
});

还有许多其他现成的类,如OpenApiBooleanOpenApiDateTime,或者如果您需要一个对象,则可以使用OpenApiObject。还有很多其他的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68954850

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档