前言
当 Swagger 遇上 Versioning 是会直接报错的哦.
幸好解决方法也不难. 做一些小配置就可以了
主要参考
Integrating ASP.NET Core Api Versions with Swagger UI
What every ASP.NET Core Web API project needs - Part 2 - API versioning and Swagger
安装 Versioning.ApiExplorer
dotnet add package Microsoft.AspNetCore.Mvc.Versioning.ApiExplorer
Program.cs
builder.Services.AddApiVersioning(options => { options.ReportApiVersions = true; }); builder.Services.AddVersionedApiExplorer(setup => { setup.GroupNameFormat = "'v'VVV"; setup.SubstituteApiVersionInUrl = true; });
public class ConfigureSwaggerOptions : IConfigureNamedOptions<SwaggerGenoptions> { private readonly IApiVersionDescriptionProvider provider; public ConfigureSwaggerOptions( IApiVersionDescriptionProvider provider) { this.provider = provider; } public void Configure(SwaggerGenoptions options) { foreach (var description in provider.ApiVersionDescriptions) { options.SwaggerDoc( description.GroupName, CreateVersionInfo(description)); } } public void Configure(string name, SwaggerGenoptions options) { Configure(options); } private OpenApiInfo CreateVersionInfo( ApiVersionDescription description) { var info = new OpenApiInfo() { Title = "Heroes API", Version = description.ApiVersion.ToString() }; if (description.IsDeprecated) { info.Description += " This API version has been deprecated."; } return info; } }
配置进去
builder.Services.AddSwaggerGen(); builder.Services.ConfigureOptions<ConfigureSwaggerOptions>();
最后是 UI
app.UseSwaggerUI(options => { foreach (var description in apiVersionDescriptionProvider.ApiVersionDescriptions) { options.SwaggerEndpoint( $"/swagger/{description.GroupName}/swagger.json", description.GroupName.toupperInvariant()); } });
这样就可以了
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。