c# - 生成 Swagger.json 文件后如何以编程方式访问它

标签 c# asp.net-core swagger swashbuckle

我正在尝试创建一个动态的 rest api,它使用 Swagger 作为 .NetCore 中的文档(使用 Swashbuckle.AspNetCore )。 动态是指只有 1 个 Controller 和 1 个可能的响应开始,但用户可以通过向服务发送 POST 添加“端点”,然后 Controller 可以转换新路由以相应地响应

为此,我需要能够访问和更改 swagger.json 文件,并更改 UI 以反射(reflect)更改 - 这可能吗?如果是怎么办?

注意:我知道我可以通过导航到/{documentname}/swagger.json 来访问和查看 swagger 文档,但这不允许我更改它

最佳答案

您可以使用自定义过滤器扩展、过滤和自定义架构: https://github.com/domaindrivendev/Swashbuckle.AspNetCore#extend-generator-with-operation-schema--document-filters

我确实用它来装饰每个请求的更多 header 字段(如授权 header )。我不确定它是否适用于整个端点。但也许值得一试。


更新(已编辑)
这是一个添加整个端点的示例 IDocumentFilter:

private class DocumentFilterAddFakes : IDocumentFilter
{
    private PathItem FakePathItem(int i)
    {
        var x = new PathItem();
        x.Get = new Operation()
        {
            Tags = new[] { "Fake" },
            OperationId = "Fake_Get" + i.ToString(),
            Consumes = null,
            Produces = new[] { "application/json", "text/json", "application/xml", "text/xml" },
            Parameters = new List<IParameter>()
                    {
                        new NonBodyParameter() // Can also be BodyParameter
                        {
                            Name = "id",
                            @In = "path",
                            Required = true,
                            Type = "integer",
                            Format = "int32",
                            @Default = 8
                        }
                    },
        };
        x.Get.Responses = new Dictionary<string, Response>();
        x.Get.Responses.Add("200", new Response() { Description = "OK", Schema = new Schema() { Type = "string" } });
        return x;
    }

    public void Apply(SwaggerDocument swaggerDoc, DocumentFilterContext context)
    {
        for (int i = 0; i < 10; i++)
            swaggerDoc.paths.Add("/Fake/" + i  + "/{id}", FakePathItem(i));
    }
}

关于c# - 生成 Swagger.json 文件后如何以编程方式访问它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45747300/

相关文章:

asp.net-core - 在 Swagger 中自动生成对 SwaggerDoc 的调用

c# - 将 foreach 循环更改为 Parallel.ForEach 循环

asp.net-core - 使用 .Net Core API 进行元组序列化

c# - Visual Studio 中是否有 Delphi 的 ActionManager 替代方案

c# - 具有区域的 ASP.NET Core 2 默认路由

javascript - 如何在单击时隐藏和显示面板?

java - 域类与 Dto 类与 Swagger 命名

java - 如何让Swagger使用@ApplicationPath?

c# - 从 32 位整数到 4 个字符的转换

c# - 如果方法运行时间太长,则中止方法的执行