using System; using System.IO; using Microsoft.AspNetCore.Builder; using Microsoft.Extensions.DependencyInjection; using Microsoft.OpenApi.Models; namespace GxPress.Api.ServiceExtensions { public static class SwaggerExtension { /// /// 添加swagger /// /// /// public static IServiceCollection AddSwashbuckle(this IServiceCollection services) { services.AddSwaggerGen(x => { x.SwaggerDoc("v1", new OpenApiInfo { Title = "GxPress API", Version = "v1", Description = "广西出版集团" }); x.CustomSchemaIds(n => n.FullName); x.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "GxPress.Api.xml"), true); x.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "GxPress.Request.xml")); x.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "GxPress.Result.xml")); x.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "GxPress.Entity.xml")); //添加token认证 x.AddSecurityRequirement(new OpenApiSecurityRequirement { { new OpenApiSecurityScheme { Reference = new OpenApiReference { Type = ReferenceType.SecurityScheme, Id = "Bearer" } }, new string[]{} } }); x.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme { Description = "JWT授权(数据将在请求头中进行传输) 直接在下框中输入Bearer {token} (注意两者之间是一个空格)", Name = "Authorization",//jwt默认的参数名称 In = ParameterLocation.Header,//jwt默认存放Authorization信息的位置 Type = SecuritySchemeType.ApiKey }); }); return services; } /// /// 使用swagger /// /// /// public static IApplicationBuilder UseSwashbuckle(this IApplicationBuilder app) { app.UseSwagger(); app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "GxPress API V1"); }); app.UseReDoc(c => { c.SpecUrl("/swagger/v1/swagger.json"); c.RoutePrefix = "docs"; c.DocumentTitle = "广西出版集团"; c.RequiredPropsFirst(); }); return app; } } }