当前位置: 首页 > article >正文

【C#.NET】Web API项目Swagger配置扩展

版本控制

注意Swagger的配置,确保每个API版本都有对应的文档描述,否则Swagger UI可能不会正确显示不同版本。可能需要使用AddSwaggerGen的多次调用,或者使用循环来动态添加各个版本的文档。

创建版本控制枚举

ApiVersions.cs

namespace Downey.Books.WebApi.SwaggerExt
{
    public enum ApiVersions
    {
        V1,
        V2,
        V3,
        V4,
        V5
    }
}

添加版本控制

#region 版本控制
typeof(ApiVersions).GetEnumNames().ToList().ForEach(version =>
{
	option.SwaggerDoc(version, new OpenApiInfo()
	{
		Title = $"Downey Api文档",
		Version = version,
		Description = $"通用版本的CoreApi版本{version}"
	});
});
#endregion

调用版本控制

app.UseSwagger();
app.UseSwaggerUI(option => 
{
    foreach(string version in typeof(ApiVersions).GetEnumNames())
    {
        option.SwaggerEndpoint($"/swagger/{version}/swagger.json", $"Downey 【{version}】版本");
    }
});

在控制器前添加版本标注

    /// <summary>
    /// 天气预报控制器
    /// </summary>
    [ApiController]
    [Route("[controller]")]
    [ApiExplorerSettings(IgnoreApi = false,GroupName = nameof(ApiVersions.V1))]
    public class WeatherForecastController : ControllerBase
    {
    	...
    }

案例展现

在这里插入图片描述

Token传值

添加token传值

#region 支持token传值
{
    option.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme()
    {
        Description = "请输入token,格式为 Bearer xxxxxx(注意中间必须有空格)",
        Name = "Authorization",
        In = ParameterLocation.Header,
        Type = SecuritySchemeType.ApiKey,
        BearerFormat = "JWT",
        Scheme = "Bearer"
    });
}
#endregion

添加安全要求

	//添加安全要求
    option.AddSecurityRequirement(new OpenApiSecurityRequirement
    {
        {
            new OpenApiSecurityScheme
            {
                Reference = new OpenApiReference()
                {
                    Type = ReferenceType.SecurityScheme,
                    Id = "Bearer"
                }
            },
            new string[] { }
        }
    });

案例演示

在这里插入图片描述
在这里插入图片描述

Swagger升级扩展

在C#中,可以通过扩展方法和扩展属性来向现有的类添加新的方法和属性。扩展方法允许我们像调用实例方法一样调用它们,而扩展属性允许我们像使用普通属性一样使用它们。

this扩展

  1. 创建一个静态类,并将其标记为static。
  2. 在该类中创建一个静态方法,该方法将是我们要添加到现有类的扩展方法。方法的第一个参数必须使用this关键字标记,并且指定要扩展的类的类型。这个参数表示我们使用扩展方法的实例。
  3. 对于扩展属性,我们可以通过创建一个静态类和一个静态方法来模拟扩展属性的行为。在方法内部,可以通过方法的名称和参数列表来实现属性的访问和值的返回。

完整代码

using Microsoft.OpenApi.Models;

namespace Downey.Books.WebApi.Utility.SwaggerExt
{
    /// <summary>
    /// Swagger扩展
    /// </summary>
    public static class CustomSwaggerExt
    {
        /// <summary>
        /// 配置Swagger
        /// </summary>
        /// <param name="services"></param>
        public static void AddSwaggerExt(this IServiceCollection services)
        {
            services.AddEndpointsApiExplorer();
            services.AddSwaggerGen(option =>
            {
                #region 支持注释
                // xml文档绝对路径--读取控制器api生成的xml文件
                var file = Path.Combine(AppContext.BaseDirectory, "Downey.Books.WebApi.xml");
                // true : 显示控制器层注释
                option.IncludeXmlComments(file, true);
                // 对action的名称进行排序
                option.OrderActionsBy(o => o.RelativePath);
                #endregion

                #region 版本控制
                typeof(ApiVersions).GetEnumNames().ToList().ForEach(version =>
                {
                    option.SwaggerDoc(version, new OpenApiInfo()
                    {
                        Title = $"Downey Api文档",
                        Version = version,
                        Description = $"通用版本的CoreApi版本{version}"
                    });
                });
                #endregion

                #region 支持token传值
                {
                    option.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme()
                    {
                        Description = "请输入token,格式为 Bearer xxxxxx(注意中间必须有空格)",
                        Name = "Authorization",
                        In = ParameterLocation.Header,
                        Type = SecuritySchemeType.ApiKey,
                        BearerFormat = "JWT",
                        Scheme = "Bearer"
                    });

                    //添加安全要求
                    option.AddSecurityRequirement(new OpenApiSecurityRequirement
                    {
                        {
                            new OpenApiSecurityScheme
                            {
                                Reference = new OpenApiReference()
                                {
                                    Type = ReferenceType.SecurityScheme,
                                    Id = "Bearer"
                                }
                            },
                            new string[] { }
                        }
                    });
                }
                #endregion

            });
        }
        /// <summary>
        /// 中间件生效
        /// </summary>
        /// <param name="app"></param>
        public static void UseSwaggerExt(this WebApplication app)
        {
            app.UseSwagger();
            app.UseSwaggerUI(option =>
            {
                foreach (string version in typeof(ApiVersions).GetEnumNames())
                {
                    option.SwaggerEndpoint($"/swagger/{version}/swagger.json", $"Downey 【{version}】版本");
                }
            });
        }
    }
}

使用扩展

#region 配置Swagger
//CustomSwaggerExt.AddSwaggerExt(builder.Services);
builder.Services.AddSwaggerExt();
#endregion

var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
	#region 使用Swagger
	//CustomSwaggerExt.UseSwaggerExt(app);
	app.UseSwaggerUI();
	#endregion
}


http://www.kler.cn/a/613629.html

相关文章:

  • vscode无法打开Terminal终端
  • 电脑连不上手机热点会出现的小bug
  • 博卡软件管理中心8:为美容美发行业量身打造的轻量级管理方案
  • swagger上传图片请求报错
  • 3.27学习总结
  • 介绍几种创意登录页(含完整源码)
  • Uniapp使用大疆SDK打包离线原生插件二
  • 力扣HOT100之普通数组:41. 缺失的第一个正数
  • uvm configuration
  • Starrocks架构及如何选择
  • 【Golang】第八弹----面向对象编程
  • Qt下载模板到本地文件内容丢失问题
  • 2025年最新自动化/控制保研夏令营预推免面试真题分享(东南大学苏州校区/华东理工/南航/天大)
  • Redis 中的过期策略和内存淘汰策略
  • 项目-苍穹外卖(十六) Apache ECharts+数据统计
  • Vue学习笔记集--pnpm包管理器
  • 企业高效访问海外SAAS应用,SD-WAN出口网络专线提高办公效率
  • 蓝桥杯备考:DFS之数独
  • Unity高渲染管线
  • linux0.11内核源码修仙传第十一章——硬盘初始化