.NET Core WebAPI中使用Swagger(完整教程)

这篇具有很好参考价值的文章主要介绍了.NET Core WebAPI中使用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工具

.NET Core WebAPI中使用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是编写多线程和并行代码的首选方式。

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

2.1-创建一个WebAPI项目

.NET Core WebAPI中使用Swagger(完整教程)


2.2-下载、安装、引入【Swashbuckle.AspNetCore】包

右击【解决方案】,然后点击【管理Nuget包】,搜索【Swashbuckle.AspNetCore】包,点击【安装】即可,博主这里下载的是【最新稳定版5.6.3】。
.NET Core WebAPI中使用Swagger(完整教程)


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 = "xxx后台管理系统",//标题
                     Description = "xxx后台管理系统:包括人员信息、团队管理等。",//描述
                     Contact=new Microsoft.OpenApi.Models.OpenApiContact { 
                         Name="西瓜程序猿",
                         Email="xxx@qq.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程序没有问题。
.NET Core WebAPI中使用Swagger(完整教程)


2.5.2-然后我们在地址栏中输入【swagger/v1/swagger.json】。
.NET Core WebAPI中使用Swagger(完整教程)


可以看到浏览器出现这样的界面,如果出现这样的界面,说明Swagger也没有问题。
.NET Core WebAPI中使用Swagger(完整教程)


注意:按照2.5.1在地址栏中的【swagger/v1/swagger.json】需要与在【Startup.cs】文件中的【Configure】类中启用Swagger中间件添加的代码保持一致,因为这段代码就是自动生成JSON文件的,你配置的路径和JSON文件地址是什么,就在浏览器中输入对应的即可。
.NET Core WebAPI中使用Swagger(完整教程)


2.5.3-以上步骤都没问题的话,然后我们地址栏中输入【swagger/index.html】。
.NET Core WebAPI中使用Swagger(完整教程)


如果能出现以下界面,说明SwaggerUI也没有问题,都全部正常了。
.NET Core WebAPI中使用Swagger(完整教程)


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

2.6.1-打开【launchSettings.json】这个文件。
.NET Core WebAPI中使用Swagger(完整教程)


2.6.2-然后将【launchUrl】的值从【weatherforecast】修改成【swagger】。
.NET Core WebAPI中使用Swagger(完整教程)


2.6.3-然后运行项目就直接进入Swagger首页了。


2.7-描述信息详细讲解

.NET Core WebAPI中使用Swagger(完整教程)
.NET Core WebAPI中使用Swagger(完整教程)


三、启用XML注释

3.1-双击解决方案
.NET Core WebAPI中使用Swagger(完整教程)


3-2-然后进入这个页面,加上这个代码
.NET Core WebAPI中使用Swagger(完整教程)

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

3-3.在【Startup.cs】文件中的【ConfigureService】类中注册读取XML信息的Swagger。
.NET Core WebAPI中使用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】控制器中写一个方法。
.NET Core WebAPI中使用Swagger(完整教程)


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 Core WebAPI中使用Swagger(完整教程)


五、小知识点

5.1-当入参/出参返回object或者匿名类时,也需要加上注释怎么办?

.NET Core WebAPI中使用Swagger(完整教程)
.NET Core WebAPI中使用Swagger(完整教程)

(1)在方法中加上以下特性:

 [ProducesResponseType(typeof(xxx),200)]

.NET Core WebAPI中使用Swagger(完整教程)


(2)在Remarks节点下进行注释:
.NET Core WebAPI中使用Swagger(完整教程)
.NET Core WebAPI中使用Swagger(完整教程)


5.2-如何隐藏接口:有接口但是不想让别人看到?

在需要进行隐藏的接口上加上以下特性即可:

  [ApiExplorerSettings(IgnoreApi =true)]

.NET Core WebAPI中使用Swagger(完整教程)


5.3-设置路由前缀/自定义头内容/网页标题

如果不想加上"swagger",而输入5000即可访问,也可以自定义路由前缀,加上以下代码即可。
.NET Core WebAPI中使用Swagger(完整教程)
.NET Core WebAPI中使用Swagger(完整教程)

5.3-自定义首页

(1)新建一个【index.html】,右击该文件,点击【属性】,进行设置相关操作。
.NET Core WebAPI中使用Swagger(完整教程)
.NET Core WebAPI中使用Swagger(完整教程)


(2)在Startup.cs进行配置。
.NET Core WebAPI中使用Swagger(完整教程)


(3)静态页面下载地址:

https://github.com/swagger-api/swagger-ui/blob/master/dist/index.html


5.4-开启JWT认证

(1)在Startup.cs进行配置。
.NET Core WebAPI中使用Swagger(完整教程)

 #region 开启JWT
   u.OperationFilter<SecurityRequirementsOperationFilter>();

	u.AddSecurityDefinition("oauth2", new Microsoft.OpenApi.Models.OpenApiSecurityScheme
	{
		Description = "JWT授权(数据将在请求头中进行传输)直接在下框中输入Bearer { token } (注意两者之间是一个空格) ",
  		Name = "Authorization",
		In = Microsoft.OpenApi.Models.ParameterLocation.Header,//jwt默认存放Authorazation信息的位置(请求头中)
		Type = Microsoft.OpenApi.Models.SecuritySchemeType.ApiKey
	});
#endregion

(2)下载包,注意版本号问题,尽量保持一致,不然会报错。
.NET Core WebAPI中使用Swagger(完整教程)


(3)然后将接口加上权限,去请求该接口,可以看到请求头中会有以下信息了。
.NET Core WebAPI中使用Swagger(完整教程)


5.5-使用Cookie持久化存储Token,解决每次刷新需要重新输入Token授权

下载相关资源。可以访问下载(如果失效了,请联系我[西瓜程序猿])。

下载地址(编码:yRLCRp81):https://yongteng.lanzoub.com/iG3Be16ayltc
密码:anum


目录结构:
.NET Core WebAPI中使用Swagger(完整教程)

(1)在【index.html】文件导入abp.js/swagger.js文件。
.NET Core WebAPI中使用Swagger(完整教程)


(2)在【swagger.js】里面需要注意请求授权地址。
.NET Core WebAPI中使用Swagger(完整教程)


(3)后端授权逻辑。
.NET Core WebAPI中使用Swagger(完整教程)
.NET Core WebAPI中使用Swagger(完整教程)
.NET Core WebAPI中使用Swagger(完整教程)


原文链接:https://www.cnblogs.com/kimiliucn/p/17602073.html文章来源地址https://www.toymoban.com/news/detail-622544.html

到了这里,关于.NET Core WebAPI中使用Swagger(完整教程)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 实战指南:使用 xUnit 和 ASP.NET Core 进行集成测试【完整教程】

    集成测试可在包含应用支持基础结构(如数据库、文件系统和网络)的级别上确保应用组件功能正常。 ASP.NET Core 通过将单元测试框架与测试 Web 主机和内存中测试服务器结合使用来支持集成测试。 集成测试与单元测试相比,能够在更广泛的级别上评估应用的组件,确认多个

    2024年04月22日
    浏览(33)
  • NET Core 6.0 webapi 简单使用+连接数据库

    ASP.NET core NET core 6.0 如何使用 在 Program.cs里面 添加对应注释 效果: Microsoft.EntityFrameworkCore.Sqlite Microsoft.EntityFrameworkCore.Sqlite.Core Newtonsoft.Json:用于Json格式转换 添加测试Api Tips:这里用到ORM查询语法 EntityFramework EF 常用增删改查语句 运行结果

    2024年02月09日
    浏览(31)
  • .net 温故知新【11】:Asp.Net Core WebAPI 入门使用及介绍

    在Asp.Net Core 上面由于现在前后端分离已经是趋势,所以asp.net core MVC用的没有那么多,主要以WebApi作为学习目标。 我使用的是VS2022, .Net 7版本。 在创建界面有几项配置: 配置Https 启用Docker 使用控制器 启用OpenAPI支持 不使用顶级语句 其中配置Https 是WebApi是否使用https协议,启

    2024年02月07日
    浏览(30)
  • .NET Core WebAPI中使用Log4net记录日志

    2024年02月20日
    浏览(28)
  • .net core 创建WebAPI以及使用EF DBFirst框架使用方法与疑问解答(.net 6)

    EF语法包: 生成实体模型: 修改实体模型: 把生成的实体和上下文都输出到某个文件夹命令 增加JSON格式脚手架: 若想增加某个版本json脚手架,需要加入后缀如: 问题与解决方案: 1、问题: Your startup project \\\'XXX\\\' doesn\\\'t reference Microsoft.EntityFrameworkCore.Design. This package is requi

    2024年02月16日
    浏览(40)
  • .NET Core WebAPI中使用Log4net 日志级别分类并记录到数据库

    记录日志为文档 记录日志到数据库

    2024年02月20日
    浏览(37)
  • 使用 Asp.net core webapi 集成配置系统,提高程序的灵活和可维护性

    集成配置系统的主要目的是将应用程序的配置信息与代码分离,使得配置信息可以在不需要修改代码的情况下进行更改。这样可以提高应用程序的灵活性和可维护性。 ASP.NET Core 提供了一种灵活的配置系统,可以轻松地将配置信息从不同的来源加载到应用程序中,并且可以根

    2024年02月01日
    浏览(52)
  • ASP.NET Core Web API入门之二:Swagger详细使用&路由设置

    本篇文章是Swagger的详细使用,续上篇ASP.NET Core Web API入门之一:创建新项目。 Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务的接口文档。 根据在代码中使用自定义的注解来生成接口文档,这个在前后端分离的项目中很重要。这样做的

    2024年02月15日
    浏览(36)
  • .Net Core WebApi

    目录 MiniMalAPi Demo Program.cs Swagger 文档+信息 Program.cs API版本控制 ApiVersion.cs Version1Controller.cs Program.cs 生成注释 解决跨域 .Net 后台请求封装 返回数据压缩 默认压缩 Gzip压缩 缓存 接口缓存 静态文件缓存 最小的api, 请求都写在Program.cs中, 可以做微服务 该例子仅供参考 这里其他版

    2024年02月14日
    浏览(36)
  • ASP.NET Core SingleR Core:WebApi + .net 客户端开发

    我之前稍微研究了一下SignalR Core。用起来还行。简单来说SignalR就是用来解决实时通讯的问题的。 ASP.NET Core SingleR:初次体验和简单项目搭建 SignalR支持三种客户端,C#,Java,JavaScirpt。基本够用了。本身就是微软开发的,肯定支持自己的语言。因为是Websocket的上层封装,所以也要支

    2024年01月20日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包