.NET Core WebAPI中使用Swagger(完整教程),NET Core WebAPI中的Swagger使用指南(完整教程)

马肤

温馨提示:这篇文章已超过461天没有更新,请注意相关的内容是否还可用!

本教程介绍了如何在.NET Core WebAPI中使用Swagger。内容包括Swagger简介、安装配置Swagger、创建Swagger文档、集成Swagger UI等步骤。通过本教程,读者可以了解如何使用Swagger为.NET Core WebAPI生成清晰的API文档,并与其他开发人员共享API接口信息,提高开发效率和协作能力。

目录

一、Swagger简介

1.1-什么是Swagger?

1.2-Swagger有什么优势?

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

1.4-Swagger工具

1.5-Swagger UI工具主要功能

1.6-Swashbuckle组件

1.7-TPL

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

2.1-创建一个WebAPI项目

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

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

2.4-启用Swagger中间件

2.5-运行项目即可

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

2.7-描述信息详细讲解

三、启用XML注释

四、实例

五、小知识点

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

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

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

5.3-自定义首页

5.4-开启JWT认证

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


一、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(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第1张

        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(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第2张

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

              右击【解决方案】,然后点击【管理Nuget包】,搜索【Swashbuckle.AspNetCore】包,点击【安装】即可,博主这里下载的是【最新稳定版5.6.3】。

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第3张

              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包版本 { 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(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第4张

              2.5.2-然后我们在地址栏中输入【swagger/v1/swagger.json】。

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第5张

              可以看到浏览器出现这样的界面,如果出现这样的界面,说明Swagger也没有问题。

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第6张

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

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第7张

              2.5.1-以上步骤都没问题的话,然后我们地址栏中输入【swagger/index.html】。

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第8张

              如果能出现以下界面,说明SwaggerUI也没有问题,都全部正常了。

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第9张

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

              2.6.1-打开【launchSettings.json】这个文件。

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第10张

              2.6.2-然后将【launchUrl】的值从【weatherforecast】修改成【swagger】。

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第11张

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

              2.7-描述信息详细讲解

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第12张

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第13张

              三、启用XML注释

              3.1-双击解决方案

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第14张

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

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第15张

              true
              $(NoWarn);1591

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

              .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第16张

                #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(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第17张

                4.2-写上以下代码然后进行请求。

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

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

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第18张

                五、小知识点

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

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第19张

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第20张

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

                 [ProducesResponseType(typeof(xxx),200)]

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第21张

                (2)在Remarks节点下进行注释:

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第22张

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第23张

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

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

                  [ApiExplorerSettings(IgnoreApi =true)]

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第24张

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

                如果不想加上"swagger",而输入5000即可访问,也可以自定义路由前缀,加上以下代码即可。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第25张

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第26张

                5.3-自定义首页

                (1)新建一个【index.html】,右击该文件,点击【属性】,进行设置相关操作。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第27张

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第28张

                (2)在Startup.cs进行配置。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第29张

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

                Swagger UI

                5.4-开启JWT认证

                (1)在Startup.cs进行配置。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第30张

                #region 开启JWT
                   u.OperationFilter();
                	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(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第31张

                (3)然后将接口加上权限,去请求该接口,可以看到请求头中会有以下信息了。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第32张

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

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

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

                密码:anum  

                目录结构:

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第33张

                (1)在【index.html】文件导入abp.js/swagger.js文件。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第34张

                (2)在【swagger.js】里面需要注意请求授权地址。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第35张

                (3)后端授权逻辑。

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第36张

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第37张

                .NET Core WebAPI中使用Swagger(完整教程),NET WebAPI中的Swagger使用指南(完整教程) 第38张

                版权声明:本文为原创文章,版权归 [西瓜程序猿] 所有,转载请注明出处,有任何疑问请私信咨询。

                原文链接:.NET Core WebAPI中使用Swagger(完整教程)_西瓜程序猿的博客-CSDN博客

                 


0
收藏0
文章版权声明:除非注明,否则均为VPS857原创文章,转载或复制请以超链接形式并注明出处。

相关阅读

  • 【研发日记】Matlab/Simulink自动生成代码(二)——五种选择结构实现方法,Matlab/Simulink自动生成代码的五种选择结构实现方法(二),Matlab/Simulink自动生成代码的五种选择结构实现方法详解(二)
  • 超级好用的C++实用库之跨平台实用方法,跨平台实用方法的C++实用库超好用指南,C++跨平台实用库使用指南,超好用实用方法集合,C++跨平台实用库超好用指南,方法与技巧集合
  • 【动态规划】斐波那契数列模型(C++),斐波那契数列模型(C++实现与动态规划解析),斐波那契数列模型解析与C++实现(动态规划)
  • 【C++】,string类底层的模拟实现,C++中string类的模拟底层实现探究
  • uniapp 小程序实现微信授权登录(前端和后端),Uniapp小程序实现微信授权登录全流程(前端后端全攻略),Uniapp小程序微信授权登录全流程攻略,前端后端全指南
  • Vue脚手架的安装(保姆级教程),Vue脚手架保姆级安装教程,Vue脚手架保姆级安装指南,Vue脚手架保姆级安装指南,从零开始教你如何安装Vue脚手架
  • 如何在树莓派 Raspberry Pi中本地部署一个web站点并实现无公网IP远程访问,树莓派上本地部署Web站点及无公网IP远程访问指南,树莓派部署Web站点及无公网IP远程访问指南,本地部署与远程访问实践,树莓派部署Web站点及无公网IP远程访问实践指南,树莓派部署Web站点及无公网IP远程访问实践指南,本地部署与远程访问详解,树莓派部署Web站点及无公网IP远程访问实践详解,本地部署与远程访问指南,树莓派部署Web站点及无公网IP远程访问实践详解,本地部署与远程访问指南。
  • vue2技术栈实现AI问答机器人功能(流式与非流式两种接口方法),Vue2技术栈实现AI问答机器人功能,流式与非流式接口方法探究,Vue2技术栈实现AI问答机器人功能,流式与非流式接口方法详解
  • 发表评论

    快捷回复:表情:
    评论列表 (暂无评论,0人围观)

    还没有评论,来说两句吧...

    目录[+]

    取消
    微信二维码
    微信二维码
    支付宝二维码