SwaggerExtension.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. using Microsoft.AspNetCore.Authentication.JwtBearer;
  2. using Microsoft.OpenApi.Models;
  3. using Swashbuckle.AspNetCore.Filters;
  4. using Swashbuckle.AspNetCore.SwaggerUI;
  5. using System.Reflection;
  6. namespace ZR.Admin.WebApi.Extensions
  7. {
  8. public static class SwaggerExtension
  9. {
  10. /// <summary>
  11. ///
  12. /// </summary>
  13. /// <param name="app"></param>
  14. public static void UseSwagger(this IApplicationBuilder app)
  15. {
  16. app.UseSwagger(c =>
  17. {
  18. c.RouteTemplate = "swagger/{documentName}/swagger.json";
  19. c.PreSerializeFilters.Add((swaggerDoc, httpReq) =>
  20. {
  21. var url = $"{httpReq.Scheme}://{httpReq.Host.Value}";
  22. var referer = httpReq.Headers["Referer"].ToString();
  23. if (referer.Contains(GlobalConstant.DevApiProxy))
  24. url = referer[..(referer.IndexOf(GlobalConstant.DevApiProxy, StringComparison.InvariantCulture) + GlobalConstant.DevApiProxy.Length - 1)];
  25. swaggerDoc.Servers =
  26. new List<OpenApiServer>
  27. {
  28. new OpenApiServer
  29. {
  30. Url = url
  31. }
  32. };
  33. });
  34. });
  35. app.UseSwaggerUI(c =>
  36. {
  37. c.SwaggerEndpoint("sys/swagger.json", "系统管理");
  38. c.SwaggerEndpoint("article/swagger.json", "文章管理");
  39. c.SwaggerEndpoint("v1/swagger.json", "business");
  40. c.SwaggerEndpoint("shopping/swagger.json", "商城管理");
  41. c.DocExpansion(DocExpansion.None); //->修改界面打开时自动折叠
  42. });
  43. }
  44. public static void AddSwaggerConfig(this IServiceCollection services)
  45. {
  46. if (services == null) throw new ArgumentNullException(nameof(services));
  47. //IWebHostEnvironment hostEnvironment = services.BuildServiceProvider().GetRequiredService<IWebHostEnvironment>();
  48. services.AddSwaggerGen(c =>
  49. {
  50. c.SwaggerDoc("sys", new OpenApiInfo
  51. {
  52. Title = "ZrAdmin.NET Api",
  53. Version = "v1",
  54. Description = "系统管理",
  55. Contact = new OpenApiContact { Name = "ZRAdmin doc", Url = new Uri("https://www.izhaorui.cn/doc") }
  56. });
  57. c.SwaggerDoc("article", new OpenApiInfo
  58. {
  59. Title = "ZrAdmin.NET Api",
  60. Version = "v1",
  61. Description = "文章管理",
  62. Contact = new OpenApiContact { Name = "ZRAdmin doc", Url = new Uri("https://www.izhaorui.cn/doc") }
  63. });
  64. c.SwaggerDoc("shopping", new OpenApiInfo
  65. {
  66. Title = "ZrAdmin.NET Api",
  67. Version = "v1",
  68. Description = "商城管理",
  69. });
  70. c.SwaggerDoc("v1", new OpenApiInfo
  71. {
  72. Title = "ZrAdmin.NET Api",
  73. Version = "v1",
  74. Description = "",
  75. });
  76. try
  77. {
  78. //var tempPath = hostEnvironment.ContentRootPath;
  79. //添加文档注释
  80. var baseDir = AppContext.BaseDirectory;
  81. c.IncludeXmlComments(Path.Combine(baseDir, "ZR.Model.xml"), true);
  82. c.IncludeXmlComments(Path.Combine(baseDir, "ZR.ServiceCore.xml"), true);
  83. c.IncludeXmlComments(Path.Combine(baseDir, "ZR.Service.xml"), true);
  84. c.IncludeXmlComments(Path.Combine(baseDir, "ZR.Admin.WebApi.xml"), true);
  85. c.IncludeXmlComments(Path.Combine(baseDir, "ZR.Mall.xml"), true);
  86. var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
  87. var xmlPath = Path.Combine(baseDir, xmlFile);
  88. c.IncludeXmlComments(xmlPath);
  89. }
  90. catch (Exception ex)
  91. {
  92. Console.WriteLine("swagger 文档加载失败" + ex.Message);
  93. }
  94. //参考文章:http://www.zyiz.net/tech/detail-134965.html
  95. //需要安装包Swashbuckle.AspNetCore.Filters
  96. // 开启权限小锁 需要在对应的Action上添加[Authorize]才能看到
  97. c.OperationFilter<AddResponseHeadersFilter>();
  98. c.OperationFilter<AppendAuthorizeToSummaryOperationFilter>();
  99. //在header 中添加token,传递到后台
  100. c.OperationFilter<SecurityRequirementsOperationFilter>();
  101. c.AddSecurityDefinition(JwtBearerDefaults.AuthenticationScheme,
  102. new OpenApiSecurityScheme
  103. {
  104. In = ParameterLocation.Header,
  105. Description = "请输入Login接口返回的Token,前置Bearer。示例:Bearer {Token}",
  106. Name = "Authorization",//jwt默认的参数名称,
  107. Type = SecuritySchemeType.ApiKey, //指定ApiKey
  108. BearerFormat = "JWT",//标识承载令牌的格式 该信息主要是出于文档目的
  109. Scheme = JwtBearerDefaults.AuthenticationScheme//授权中要使用的HTTP授权方案的名称
  110. });
  111. c.AddSecurityRequirement(new OpenApiSecurityRequirement
  112. {
  113. {
  114. new OpenApiSecurityScheme
  115. {
  116. Reference = new OpenApiReference { Type = ReferenceType.SecurityScheme, Id = "Bearer" }
  117. },
  118. new List<string>()
  119. }
  120. });
  121. try
  122. {
  123. //判断接口归于哪个分组
  124. c.DocInclusionPredicate((docName, apiDescription) =>
  125. {
  126. if (docName == "v1")
  127. {
  128. //当分组为NoGroup时,只要没加特性的都属于这个组
  129. return string.IsNullOrEmpty(apiDescription.GroupName);
  130. }
  131. else
  132. {
  133. return apiDescription.GroupName == docName;
  134. }
  135. });
  136. }
  137. catch (Exception e)
  138. {
  139. Console.WriteLine(e);
  140. throw;
  141. }
  142. });
  143. }
  144. }
  145. }