在.NET Core Web API 中应用 Swagger

一、Swagger简介

1.1 什么是Swagger?

  • Swagger是一个规范且完整的框架,用于生成、描述、调试和可视化 Restfull 风格的Web服务
  • Swagger的目标是对Rest API定义一个标准且和语言无关的接口,可以让人和计算机拥有无需访问源码、文档或网络流量监控就可以发现和连接服务的能力。当通过Swagger进行正确定义,用于可以理解远程服务并使用最少逻辑与远程服务进行交互。与为底层编程所实现的接口类似,Swagger消除了调用服务时可能会有的猜测

1.2 Swagger有什么优势?

  • 支持API自动生成同步的在线文档:使用Swagger后可以直接通过代码生成文档,不需要自己去手动编写接口文档了,对程序员来说是非常方便
  • 提供Web页面在线测试API:光有文档还不够,Swagger生成的文档还支持在线测试。参数和格式都一定定义好了,直接在界面上输出参数对应的值即可在先测试接口
  • Swagger可以生成客户端SDK代码用于各种不同平台的实现
  • Swagger文件可以在许多不同的平台上从代码注释中自动生成
  • Swagger有一个强大的社区,里面有许多强悍的贡献者

1.3 Swagger、OpenAPI3.0、Restful API的区别?

  • Open API=规范:OpenAPI是规范的正式名称。该规范的开发时由OpenAPI Initative推动的。该提倡涉及不同领域的30个组织——包括Microsoft、Google、IBM和CapitalOne
  • Swagger=实现OpenAPI规范的工具之一
  • RestfulAPI=一种WebAPI设计架构风格。其中Rest即Represntaional State Transfer的缩写,可以翻译为"状态表述转换"。是目前比较成熟的一套互联网应用程序的API设计架构风格OpenAPI规范即是这个架构风格的具体实现规范

1.4 Swagger工具

在这里插入图片描述

1.5 Swagger UI工具主要功能

  • 接口的文档在线自动生成
  • 功能测试等

1.6 Swashbuckle组件

  • Swashbuckle是.NET Core中对Swagger的封装,他有2个核心组件:
    • Swashbuckle.SwaggerGen:提供生成对象、方法、返回类型等JSON Swagger文档的功能
    • Swashbuckle.SwaggerUI:是一个嵌入式版本的SwaggerUI工具,使用Swagger UI强大的富文本表现形式可定制化的来描述Web API的功能,并且包含内置的公共方法测试工具

1.7 TPL

  • 任务并行库(TPL)是System.Threading.Tasks命名空间中的一组公共类型和API
  • TPL动态的扩展并发度,以最有效的使用可用的处理器。通过使用TPL,您可以最大限度的提高代码的性能,同时专注于您的代码业务
  • 从.NETFramework4开始,TPL是编写多线程和并行代码的首选方式

二、在.NET Core Web API中使用Swagger UI

2.1 创建一个WebAPI项目

在这里插入图片描述

2.2 下载、安装、引入Swashbuckle.AspNetCore

  • 打开Nuget包管理器,搜索Swashbuckle.AspNetCore包,点击【安装】即可
    在这里插入图片描述

2.3 配置Swagger中间件(注册 Swagger 服务)

  • Startup.cs文件中的ConfigureService类中引入命名空间,并注册 Swagger 服务并配置文档信息
//引入命名空间
using Microsoft.OpenApi.Models;

//注册Swagger
services.AddSwaggerGen(u =>
{
    u.SwaggerDoc("v1", new Microsoft.OpenApi.Models.OpenApiInfo
    {
        Version = "Ver:1.0.0",//版本
        Title = "后台管理系统",//标题
        Description = "后台管理系统:包括学生信息、部门管理等。",//描述
        Contact = new Microsoft.OpenApi.Models.OpenApiContact
        {
            Name = "UserName",
            Email = "***@hotmail.com"
        }
    });
});
  • 如果安装的 Swashbuckle.AspNetCore Nuget 包版本 <= 3.0.0,写法略有不同。将 OpenApiInfo 替换成 【Info】 即可
services.AddSwaggerGen(x =>
{
	x.SwaggerDoc("v1", new Info() { Title = "Web Api", Version = "v1" });
});

2.4 启用Swagger中间件

  • Startup.cs文件中的Configure类中启用Swagger中间件,为生成的 JSON 文档和SwaggerUI 提供服务
//启用Swagger中间件
app.UseSwagger();
//配置SwaggerUI
app.UseSwaggerUI(u =>
{
    u.SwaggerEndpoint("/swagger/v1/swagger.json", "WebAPI_v1");
});

2.5 运行项目

  • 2.5.1 如果我们直接运行项目,会出现这样的界面,说明我们的Web API程序没有问题。
    在这里插入图片描述
  • 然后我们在地址栏中输入swagger/v1/swagger.json
    在这里插入图片描述
  • 可以看到浏览器出现这样的界面,如果出现这样的界面,说明Swagger也没有问题
    在这里插入图片描述
    注意:按照2.5.1在地址栏中的swagger/v1/swagger.json需要与在Startup.cs文件中的【Configure】类中启用Swagger中间件添加的代码保持一致,因为这段代码就是自动生成 JSON 文件的,你配置的路径和 JSON 文件地址是什么,就在浏览器中输入对应的即可
    在这里插入图片描述
  • 以上步骤都没问题的话,然后我们地址栏中输入swagger/index.html
    在这里插入图片描述
  • 这是Swagger的首页,如果能出现以下界面,说明SwaggerUI也没有问题,都全部正常了
    在这里插入图片描述

2.6 如果想每次运行都默认直接到Swagger的页面

  • 打开launchSettings.json这个文件
    在这里插入图片描述
  • 然后将launchUrl的值从weatherforecast修改成swagger
  • 修改变成以下代码
    在这里插入图片描述
  • 然后运行项目就直接进入Swagger首页了

2.7 描述信息详细讲解

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

三、启用XML注释

3.1 双击解决方案

在这里插入图片描述

3-2 然后进入这个页面,加上这个代码

在这里插入图片描述

<GenerateDocumentationFile>true</GenerateDocumentationFile>
<NoWarn>$(NoWarn);1591</NoWarn>

3-3 在Startup.cs文件中的ConfigureService类中注册读取XML信息的Swagger

#region 读取xml信息
// 使用反射获取xml文件,并构造出文件的路径
var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile);
// 启用xml注释,该方法第二个参数启用控制器的注释,默认为false.
u.IncludeXmlComments(xmlPath, true);
#endregion

在这里插入图片描述
注意:

  • 对于Linux或者非Windows操作系统,文件名和路径区分大小写。例如:MyWebApiUseSwagger.xml文件在Windows上有效,但在CentOS上是无效的
  • 获取应用程序路径,建议采用Path.GetDirectoryName(typeof(Program).Assembly.Location)这种方式或者AppContext.BaseDirectory这样来获取

四、实例

4.1 写一个实例:在WeatherForecastController控制器中写一个方法

在这里插入图片描述

4.2 写上以下代码然后开始请求

/// <summary>
/// 这是一个例子
/// </summary>
/// <remarks>
/// 描述:这是一个带参数的GET请求
/// Web API
/// </remarks>
/// <param name="id">主键ID</param>
/// <returns>测试字符串</returns>
[HttpGet("{id}")]
public ActionResult<string> Get(int id)
{
    return $"你请求的ID是:{id}";
}

4.3 可以看到 XML注释 起作用了,然后调用也成功了

在这里插入图片描述

五 .Net Core3.1 swagger 文档添加 不用 xml 配置

四中使用 特性的方式来自动生成 swagger 文档的方式,简述的较为笼统,如果没明白请转到博客:.Net Core3.1 swagger 文档添加 不用xml配置

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在IIS上部署ASP.NET Core Web API项目及Swagger可以按照以下步骤进行: 1. 首先,我们需要确保已经在本地系统上安装了ASP.NET Core Runtime和ASP.NET Core Hosting Bundle,以便在IIS运行ASP.NET Core应用程序。 2. 在Visual Studio,打开你的ASP.NET Core Web API项目。确保项目已经设置为IIS Express作为本地开发服务器。 3. 在项目根目录下的`Properties`文件夹找到`launchsettings.json`文件,检查并确保该文件已经配置了`applicationUrl`为`http://localhost:{port}/`,其`port`为你希望的端口号。 4. 在Visual Studio的顶部菜单,找到 `Build` -> `Publish {YourProjectName}`,选择发布目标为`Folder`,点击 `Publish`。 5. 在弹出的窗口选择一个输出文件夹,用于存储发布项目的文件。 6. 打开发布文件夹,在该文件夹应该有一个名为`web.config`的文件。双击打开该文件,确保其有以下代码片段: ```xml <aspNetCore processPath="dotnet" arguments=".\{YourProjectName}.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false" /> ``` 7. 打开IIS管理器,右键点击`Sites`节点,选择`Add Website`。填写网站名称以及物理路径为刚刚发布项目的目录。 8. 对于应用程序池,选择一个合适的.NET CLR版本和托管管道模式(例如:.NET CLR版本为No Managed Code,托管管道模式为集成)。 9. 在网站的右侧,找到`Authentication`,禁用匿名身份验证并启用Windows身份验证。 10. 重新启动IIS。 11. 现在,我们可以在浏览器访问`http://localhost:{port}`,应该能够看到你的ASP.NET Core Web API已经在IIS上成功部署。 12. 最后,要在部署的项目添加Swagger,可以通过NuGet包管理器,添加`Swashbuckle.AspNetCore`包。 13. 在`Startup.cs`文件的`ConfigureServices`方法,添加以下配置: ```csharp services.AddSwaggerGen(c => { c.SwaggerDoc("v1", new OpenApiInfo { Title = "API", Version = "v1" }); }); ``` 14. 在`Startup.cs`文件的`Configure`方法,添加以下代码: ```csharp app.UseSwagger(); app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "API v1"); }); ``` 15. 重新发布并重新启动IIS,现在你的ASP.NET Core Web API应该在IIS上部署并且通过Swagger可以浏览和调用你的API接口。 以上就是在IIS上部署ASP.NET Core Web API项目及Swagger的步骤。请注意,确保按照正确的顺序执行每一步,并根据自己的项目配置进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黑夜中的潜行者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值