Добавить опцию токена на предъявителя в swagger для конкретной версии в веб-API - PullRequest
8 голосов
/ 27 мая 2020

Я использую Swagger в приложении веб-API. У меня несколько версий API, но я хочу применить параметр токена на предъявителя только к версии 2. Для обеих версий нет аутентификации. Вот мой код:

services.AddSwaggerGen(c =>
{
    c.SwaggerDoc("v1", new OpenApiInfo { Title = "My API", Version = "v1" });
    c.SwaggerDoc("v2", new OpenApiInfo { Title = "My API", Version = "v2" });

    c.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme
    {
        In = ParameterLocation.Header,
        Description = "JWT Authorization header using the Bearer scheme. Example: \"Authorization: Bearer {token}\"",
        Name = "Authorization",
        Type = SecuritySchemeType.ApiKey,         
    });
});

enter image description here enter image description here

Ответы [ 2 ]

4 голосов
/ 01 июня 2020

Другой способ решения этой проблемы, я предполагаю, что у вас есть префикс для версии контроллера v1 в качестве префикса, тогда вы можете сделать следующее:

public class AuthorizationHeaderParameterOperationFilter : IOperationFilter
{
    public void Apply(OpenApiOperation operation, OperationFilterContext context)
    {
        if (operation.Parameters == null)
            operation.Parameters = new List<OpenApiParameter>();

        if (context.ApiDescription.RelativePath.StartsWith("v2"))
        {
            operation.Parameters.Add(new OpenApiParameter()
            {
                @In = ParameterLocation.Header,
                Description =
                    "JWT Authorization header using the Bearer scheme. Example: \"Authorization: Bearer {token}\"",
                Name = "Authorization",
            });
        }

    }
}

и использовать его

services.ConfigureSwaggerGen(options =>
{
    options.OperationFilter<AuthorizationHeaderParameterOperationFilter>();
});

Это только добавит поле Bearer к конечным точкам v2.

enter image description here

enter image description here

3 голосов
/ 01 июня 2020

Вы можете установить NSwag.AspNetCore и добавить различные параметры с разными версиями.

services.AddSwaggerDocument(a =>
{
    a.DocumentName = "v1";
    a.Version = "v1";
});

services.AddSwaggerDocument(a =>
{
    a.DocumentName = "v2";
    a.Version = "v2";
    a.AddSecurity("bearer", new NSwag.OpenApiSecurityScheme
    {
        Description = "jwt",
        In = NSwag.OpenApiSecurityApiKeyLocation.Header,
        Type = NSwag.OpenApiSecuritySchemeType.ApiKey,
        Scheme = "bearer"
    });
});
app.UseOpenApi();
app.UseSwaggerUi3();

Подробнее об этом можно прочитать в Microsoft Docs .

...