.Net7配置swagger进行添加接口注释

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言

".NET 7" 是指.NET 平台的第七个主要版本,是微软开发的一个跨平台应用开发框架。


一、创建Web API项目

  1. 在VS 2022中 选择 ASP .NET Core Web API 项目 进行创建,填写项目名称和解决方案名称,点击 "下一步"

  2. 勾选 启用 OPenAPI 支持 以及 使用控制器 两项

  3. 项目启动,可以看到 Swagger 已经成功运行出来了

二、配置Swagger

1.注释配置

我们在代码通常会对api接口注释,而这部分注释也希望能通过Swagger展示出来,应该如何做呢

(1) 通过NuGet包管理器安装Swashbuckle.AspNetCore包(创建项目时默认已添加,无需再次安装)

(2)配置Swagger生成器:在Program.cs文件中,添加以下代码以配置

bash 复制代码
services.AddSwaggerGen(c =>
{
    c.SwaggerDoc("v1", new OpenApiInfo { Title = "Web API", Version = "v1" });
});
  1. 启用Swagger中间件
bash 复制代码
app.UseSwagger();
app.UseSwaggerUI(c => {
    c.SwaggerEndpoint("/swagger/v1/swagger.json", "Web API V1");
});
  1. 在控制器的操作方法上添加注释:在控制器操作方法上,添加XML注释以描述该方法
bash 复制代码
/// <summary>
/// This is a sample operation with XML comments
/// </summary>
/// <response code="200">Success</response>
[HttpGet(Name = "GetWeatherForecast")]
  1. 在项目 " 属性" 中启用XML文档生成,将XML文档文件包含到Swagger配置中

    如果不配置 生成API文档的文件,则Swagger UI 会报错
  1. 配置Swagger显示注释:在Swagger配置中将XML文档文件包含在注释中,以便Swagger可以读取和显示XML
bash 复制代码
services.AddSwaggerGen(c =>
{
    c.SwaggerDoc("v1", new OpenApiInfo { Title = "Your API Name", Version = "v1" });
    
    // Configure Swagger to use the XML documentation file generated by Visual Studio
    var xmlFile = $"{Assembly.GetEntryAssembly().GetName().Name}.xml";
    var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile);
    c.IncludeXmlComments(xmlPath);
});
  1. 配置完成,重新生成项目,此时可以看到在 关于 GetWeatherForecast接口注释 已经在 " Swagger UI" 中成功显示了

总结

以上就是今天要讲的内容,本文通过以上步骤,可以配置Swagger以显示.NET代码中的接口注释。希望这些说明可以帮助您实现您的目标。如果您需要进一步的帮助,请随时告诉我。

相关推荐
小北方城市网13 小时前
第 5 课:Vue 3 HTTP 请求与 UI 库实战 —— 从本地数据到前后端交互应用
大数据·前端·人工智能·ai·自然语言处理
踢球的打工仔13 小时前
ajax的基本使用(上传文件)
前端·javascript·ajax
樊小肆13 小时前
ollmam+langchain.js实现本地大模型简单记忆对话-内存版
前端·langchain·aigc
徐小夕13 小时前
pxcharts 多维表格开源!一款专为开发者和数据分析师打造的轻量化智能表格
前端·架构·github
电商API&Tina13 小时前
跨境电商速卖通(AliExpress)数据采集与 API 接口接入全方案
大数据·开发语言·前端·数据库·人工智能·python
bugcome_com13 小时前
深入解析 C# 中 int? 与 int 的核心区别:可空值类型的本质与最佳实践
开发语言·c#
Lv117700814 小时前
Visual Studio中的常量和只读变量
ide·笔记·c#·visual studio
Mintopia14 小时前
🏗️ B端架构中的用户归因与埋点最佳实践
前端·react.js·架构
码界奇点14 小时前
基于Gin+Vue的前后端分离权限管理系统设计与实现
前端·vue.js·车载系统·毕业设计·gin·源代码管理
LYFlied14 小时前
前端跨端技术全景解析:从本质到未来
前端·职场和发展·跨端