ASP .NET Core从零到壹 || Swagger配置(一)
2023-04-20 21:20:03 博客园

ASP .NET Core系列之Swagger配置(一)

官方文档:带有 Swagger/OpenAPI 的 ASP.NET Core Web API 文档 | Microsoft Learn

开发环境:VS2022+net6


【资料图】

目录

启用OpenAPI支持(建议)

在新建项目时,建议勾选启用OpenAPI支持,勾选后会自动添加Swagger基本配置,直接看下一节即可

手动添加OpenAPI

  1. 安装Nuget包Install-Package Swashbuckle.AspNetCore -Version 6.2.3
  2. 改造Program.cs在var app = builder.Build();前添加:
builder.Services.AddEndpointsApiExplorer();builder.Services.AddSwaggerGen()

var app = builder.Build();后添加:

app.UseSwagger();app.UseSwaggerUI();

版本控制

  1. 新建版本说明类
public enum ApiVersions{/// /// 第一版/// V1,/// /// 第二版/// V2}
  1. 改造Program.cs
builder.Services.AddSwaggerGen(options =>{    #region 分版本的Swagger配置    //要启用swagger版本控制要在api控制器或者方法上添加特性[ApiExplorerSettings(GroupName = "版本号")],这里是枚举    typeof(ApiVersions).GetEnumNames().ToList().ForEach(version =>    {        options.SwaggerDoc(version, new Microsoft.OpenApi.Models.OpenApiInfo()        {            Title = $"当前版本{version}",            Version = version,            Description = $"这是第{version}版本"        });    });    #endregion});
app.UseSwaggerUI(opotions =>{    typeof(ApiVersions).GetEnumNames().ToList().ForEach(version =>    {        opotions.SwaggerEndpoint($"/swagger/{version}/swagger.json", $"版本:{version}");    });});
  1. 在控制器或操作方法上标记版本
[ApiExplorerSettings(GroupName = nameof(ApiVersions.V1))]public class WeatherForecastController : ControllerBase

注释显示

显示效果

  1. 生成XML注释文档

本质:生成一个WebApplication1.xml文件注意:如果参数的Model在其它类库,那么所引用的类库的.csproj文件也要加上上面的标识,并在Program.cs引入程序集的xml文件才能展示参数的注释

  1. 改造Program.cs文件
builder.Services.AddSwaggerGen(options =>{    #region 显示注释    // xml文档绝对路径    var file = Path.Combine(AppContext.BaseDirectory, "WebApplication1.xml");    //true:显示控制器层注释    options.IncludeXmlComments(file, true);    //对action的名称进行排序,如果有多个,就可以看见效果了。    options.OrderActionsBy(o => o.RelativePath);    #endregion});

Token传递

效果显示

改造Program.cs文件:

builder.Services.AddSwaggerGen(options =>{    #region 传入Token    //添加安全定义    options.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme    {        Description = "请输入token,格式为Bearer xxxxxxxx(注意中间必须有空格)",        Name = "Authorization",        In = ParameterLocation.Header,        Type = SecuritySchemeType.ApiKey,        BearerFormat = "JWT",        Scheme = "Bearer"    });    // 添加安全要求    options.AddSecurityRequirement(new OpenApiSecurityRequirement    {        {            new OpenApiSecurityScheme            {                Reference = new OpenApiReference                {                    Type = ReferenceType.SecurityScheme,                    Id = "Bearer"                }            },            new List()        }    });    #endregion});

文件上传

效果显示

默认来说,Swagger是没有选择文件这个按钮的,但是当有API是要接收文件时就不方便测试了,这里可以通过增加一个IOperationFilter,也就是重写操作某个特定API的的过滤器来实现。

net6自带的Swagger支持的是OpenAPI 3,需要根据OpenAPI 3的规范来实现。

OpenAPI 3规范:

requestBody:  content:    multipart/form-data:      schema:        type: object        properties:          fileName:            type: string            format: binary

实现方式:

  1. 根据上面的规范,重新设置requestBody,代码如下:
public class FileUploadFilter : IOperationFilter{    public void Apply(OpenApiOperation operation, OperationFilterContext context)    {        //判断上传文件的类型,只有上传的类型是IFormCollection的才进行重写。        if (context.ApiDescription.ActionDescriptor.Parameters.Any(w => w.ParameterType == typeof(IFormCollection)))        {            Dictionary schema = new Dictionary();            schema["fileName"] = new OpenApiSchema { Description = "Select file", Type = "string", Format = "binary" };            Dictionary content = new Dictionary();            content["multipart/form-data"] = new OpenApiMediaType { Schema = new OpenApiSchema { Type = "object", Properties = schema } };            operation.RequestBody = new OpenApiRequestBody() { Content = content };        }    }}
  1. 改造Program.cs
builder.Services.AddSwaggerGen(options =>{    #region 文件上传按钮    options.OperationFilter();    #endregion}
  1. 控制器方法示例
[HttpPost]public JsonResult UploadFile(IFormCollection form){    return new JsonResult(new                          {                              Success = true,                              Message = "上传成功",                              FileName = form.Files.FirstOrDefault()?.FileName                          });}

热门推荐

文章排行

  1. 2023-04-20ASP .NET Core从零到壹 || Swagger配置(一)
  2. 2023-04-20徐工挖机与海江集团达成战略协议_视焦点讯
  3. 2023-04-20环球要闻:南京牙友终于讲真话:种牙不慎重挑选医院会吃大亏!告诉你南京真正靠谱正规的种植牙医院
  4. 2023-04-20首善之区 低碳理念成共识-每日快播
  5. 2023-04-20世界简讯:规范“达人探店” 不妨将其定性成商业广告
  6. 2023-04-20热闹的上海车展,落寞的上汽集团!
  7. 2023-04-20千防万防,猝不及防,儿子还是近视了!医生给了最新方案!
  8. 2023-04-20博科测试IPO上会在即:控制权稳定性藏隐忧,宝克公司兼客户和供应商双重身份 全球头条
  9. 2023-04-2001095558是中信银行吗 01095558|报道
  10. 2023-04-20琼中今年将打造千亩有机茶示范基地-全球新消息
  11. 2023-04-20中国上市公司协会柳磊:注册制改革以来,超八成科创板上市公司上市前获私募基金投资_世界今头条
  12. 2023-04-20浙江高校一段柯尔克孜族舞蹈火出圈 网友:天赋刻进了DNA
  13. 2023-04-20活性氧Pargyline (hydrochloride),CAS No. 306-07-0
  14. 2023-04-20别克郭越:E5兼顾家用/商务场合,且具有性价比-天天速讯
  15. 2023-04-20环球快看点丨美报告:美国正被仇恨心理摧毁 国内极端主义爆炸性增长
  16. 2023-04-20素炒洋姜正宗做法? 焦点观察
  17. 2023-04-2023大唐环境SCP002(科创票据)票面利率为2.3600%|热门看点
  18. 2023-04-20预装鸿蒙3.0,华为新机明天推出,支持北斗卫星消息
  19. 2023-04-20bread的音标_音标怎么读
  20. 2023-04-20天台岭商房地产开发有限公司未取得施工许可证擅自施工被罚37.5万元