安装:Swashbuckle.AspNetCore

  启用 XML 注释:右键单击“解决方案资源管理器”中的项目,然后选择“属性”。勾选“生成”选项卡的“输出”部分下的“XML 文档文件”框。

  将 Swagger 生成器添加到 Startup.ConfigureServices 方法中的服务集合中:

  注册Swagger生成器,定义一个和多个Swagger 文档

services.AddSwaggerGen(c =>
{
     c.SwaggerDoc("v1", new Info { Title = "API", Version = "v1" });
     //加载注释文件
     var xmlPath = Path.Combine(AppInfo.BaseDirectory,  "***.xml");
     c.IncludeXmlComments(xmlPath);
     //启用数据注解
     c.EnableAnnotations();
});

  在 Startup.Configure 方法中,启用中间件为生成的 JSON 文档和 Swagger UI 提供服务:

app.UseSwagger();
app.UseSwaggerUI(c =>
{
    c.SwaggerEndpoint("/swagger/v1/swagger.json", "v1");
});

  需要注意的是使用该API文档功能时控制器的路由不能使用模板路由,而是要在控制器上面使用特性路由。

  启动应用,并导航到 http://localhost:<port>/swagger/index.html可以看到Api文档。

  默认情况下文档是不包含控制器注释的,需要另外添加。添加包:Swashbuckle.AspNetCore.Annotations

  在控制器上增加注解: [SwaggerTag("***")]

  分组的话可以在控制器上增加注解:[ApiExplorerSettings(GroupName = "***")]。然后在services.AddSwaggerGen和services.UseSwaggerUI时根据特性ApiExplorerSettings中的GroupName动态生成文档。