ASP.NET Core怎么使用Swagger OpenAPI接口文档生成方法

ASP.NET Core 项目集成 Swagger 需四步:1. 安装 Swashbuckle.AspNetCore 包;2. 在 Program.cs 中配置 AddEndpointsApiExplorer、AddSwaggerGen 及 UseSwagger/UseSwaggerUI;3. 启用 XML 注释并配置读取路径以增强文档信息;4. 可选支持多版本,通过 SwaggerDoc 和 SwaggerEndpoint 实现。

asp.net core怎么使用swagger openapi接口文档生成方法

ASP.NET Core 项目中集成 Swagger(即 Swashbuckle.AspNetCore)是生成 OpenAPI 接口文档最常用、最标准的方式。它能自动扫描控制器和 API 方法,生成交互式文档页面,并支持测试接口。

1. 安装 Swashbuckle.AspNetCore 包

在项目中通过 NuGet 安装核心包:

Swashbuckle.AspNetCore(主包,含生成器、UI 和中间件)

可通过 CLI 命令安装:

dotnet add package Swashbuckle.AspNetCore

2. 配置服务与中间件(Program.cs)

.NET 6+ 项目统一在 Program.cs 中配置:

调用 AddEndpointsApiExplorer()(必需,为 API 端点提供元数据) 调用 AddSwaggerGen() 添加 Swagger 生成器 在管道中使用 UseSwagger()UseSwaggerUI()

示例代码:

var builder = WebApplication.CreateBuilder(args);
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();

var app = builder.Build();
app.UseSwagger();
app.UseSwaggerUI();

3. 添加接口注释与增强文档信息

默认只显示方法名和路径。要显示更详细的描述、参数说明、返回值等,需启用 XML 注释:

在项目文件(.csproj)中添加:trueAddSwaggerGen() 中配置读取 XML 文件:

builder.Services.AddSwaggerGen(c =>
{
  c.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, “YourProjectName.xml”));
});

并在控制器/方法上写三斜杠注释,例如:

///

获取用户列表

/// 用户集合
[HttpGet(“users”)]
public IEnumerable GetUsers() => …;

4. 支持多版本 OpenAPI 文档(可选)

如需支持 v1/v2 多版本 API,可配置多个 Swagger 文档:

AddSwaggerGen() 中定义多个 c.SwaggerDoc("v1", ...)UseSwaggerUI() 指定默认版本和切换入口

示例片段:

builder.Services.AddSwaggerGen(c =>
{
  c.SwaggerDoc(“v1”, new OpenApiInfo { Title = “My API v1”, Version = “v1” });
  c.SwaggerDoc(“v2”, new OpenApiInfo { Title = “My API v2”, Version = “v2” });
});

app.UseSwaggerUI(c =>
{
  c.SwaggerEndpoint(“/swagger/v1/swagger.json”, “My API V1”);
  c.SwaggerEndpoint(“/swagger/v2/swagger.json”, “My API V2”);
});

基本上就这些。启动应用后访问 /swagger 即可看到交互式文档页面,所有标记了 HTTP 特性的控制器方法都会自动列出。

以上就是ASP.NET Core怎么使用Swagger OpenAPI接口文档生成方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1443178.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 19:49:49
下一篇 2025年12月17日 19:50:00

相关推荐

发表回复

登录后才能评论
关注微信