本节导航

  • Swagger介绍

  • 在ASP.NET CORE 中的使用swagger


  在软件开发中,管理和测试API是一件重要而富有挑战性的工作。在我之前的文章《研发团队,请管好你的API文档》 也专门阐述了通过文档管理工具,来保证API文档和代码的一致性,这样更加有助于团队的协作。

  以往我们总是通过第三方平台工具来管理我们的API文档,如eolinker。在测试方面,我们也会依赖fiddler,PostMan这样的工具。

  Swagger兼具了API文档管理和测试的功能,而且保证了代码和文档的一致性。它提供了无需任何实现逻辑的RESTfulAPI的UI表示。它允许用户在没有任何代码访问的情况下了解服务的功能,并减少创建服务文档的时间。

1 Swagger介绍

  Swagger兼具了API文档管理和测试的功能,而且保证了代码和文档的一致性。它提供了无需任何实现逻辑的RESTfulAPI的UI表示。它允许用户在没有任何代码访问的情况下了解服务的功能,并减少创建服务文档的时间。

  swagger使用swagger工具基于我们编写的服务代码生成的swagger.json文件来生成文档管理界面。此文件描述服务的功能,即服务支持多少方法,并提供有关方法参数的信息。使用这个文件,SwaggerUI生成客户机代码。下面是swagger.json文件的一个示例。

{    "swagger": "2.0",    "info": {        "version": "1.0",        "title": "My Demo API"    },    "paths": {        "/api/Values": {            "get": {                "tags": ["Values"],                "summary": "Get values",                "operationId": "Get",                "consumes": [],                "produces": ["text/plain", "application/json", "text/json"],                "parameters": [],                "responses": {                    "200": {                        "description": "Success",                        "schema": {                            "uniqueItems": false,                            "type": "array",                            "items": {                                "type": "string"                            }                        }                    }                }            },            "post": {                "tags": ["Values"],                "operationId": "Post",                "consumes": ["application/json-patch+json", "application/json", "text/json", "application/*+json"],                "produces": [],                "parameters": [{                    "name": "value",                    "in": "body",                    "required": false,                    "schema": {                        "type": "string"                    }                }],                "responses": {                    "200": {                        "description": "Success"                    }                }            }        }    },    "definitions": {}}

  在APS.NET Core Web API 中,我们可以用Swashbuckle.AspNetCore 和 NSwag这两个包来实现Swagger,而且二者都是github上开源的。此外,nswag还提供了生成typescript客户端代码的方法以及用于API的服务代码。

2 在ASP.NET CORE 中的使用swagger

  这里以Swashbuckle.AspNetCore来实现。

  以下是在ASP.net Core Web API中配置Swagger的步骤:

1. 安装Swashbuckle.AspNetCore

PM> Install-Package Swashbuckle.AspNetCore

2. 配置swagger中间件

  要将swagger middle添加到请求管道,需要在startup类的configureService方法中添加swaggergen方法。在这里,我们可以定义一个或多个swagger XML文档。

Startup.cs

// This method gets called by the runtime. Use this method to add services to the container.        public void ConfigureServices(IServiceCollection services)        {            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);            services.AddSwaggerGen(c =>            {                c.SwaggerDoc("v1.0", new Info { Title = "My Demo API", Version = "1.0" });                c.IncludeXmlComments(System.IO.Path.Combine(System.AppContext.BaseDirectory, "ZhiKeCore.API.xml"));            });        }

  如果要启用这个中间件,我们还需要在startup类的configure方法中调用useswagger方法。在这里,我们还需要配置swagerendpoint来生成UI。useswagegrui将添加一个静态文件中间件来加载swager.json文件。

// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.        public void Configure(IApplicationBuilder app, IHostingEnvironment env)        {            if (env.IsDevelopment())            {                app.UseDeveloperExceptionPage();            }            else            {                // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.                app.UseHsts();            }            app.UseHttpsRedirection();            app.UseMvc();            app.UseSwagger();            app.UseSwaggerUI(c =>            {                c.SwaggerEndpoint("/swagger/v1.0/swagger.json", "My Demo API (V 1.0)");            });        }

  以上是配置swagger的基本步骤,如果我们想使用Visual Studio在开发环境中启动Swagger,还需要做一点设置。选择项目-属性-Debug,修改启动浏览器(Launch Browser)的值为swagger。

  当我们启动程序以后,可以看到如下界面:

  正如我们在这里看到的,它对每个HTTP动词使用不同的颜色代码。当我们单击任何操作方法时,它将询问参数详细信息,当我们单击“非常”按钮时,它将向Web API发送请求。

  在测试我们的WebAPI时,Swagger只需要最少的配置即可。

  那么,如果我们想要在UI上显示代码注释应该怎么办呢?

  在.NET Core中,我们可以通过在项目属性窗口的“构建”选项卡下设置“XML文档文件”属性来获取XML注释。

  默认情况下,Swagger UI不显示此文档。我们需要传递包含exmlcomments的路径。

// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.       // This method gets called by the runtime. Use this method to add services to the container.        public void ConfigureServices(IServiceCollection services)        {            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);            services.AddSwaggerGen(c =>            {                c.SwaggerDoc("v1.0", new Info { Title = "My Demo API", Version = "1.0" });                c.IncludeXmlComments(System.IO.Path.Combine(System.AppContext.BaseDirectory, "ZhiKeCore.API.xml"));            });        }

参考

  • https://www.c-sharpcorner.com/article/test-your-asp-net-core-web-api-with-swagger/

  • http://www.zhikestreet.com/Home/Detail/6/

原文地址:https://www.cnblogs.com/lucky_hu/p/11130209.html


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

ASP.NET Core Web API中使用Swagger相关推荐

  1. 在ASP.NET Core Web API上使用Swagger提供API文档

    我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的API文档功能.当设置IISExpress的默认启动路由到Swagger的API文档页 ...

  2. 在 ASP.NET Core Web API中使用 Polly 构建弹性容错的微服务

    在 ASP.NET Core Web API中使用 Polly 构建弹性容错的微服务 https://procodeguide.com/programming/polly-in-aspnet-core ...

  3. [译]ASP.NET Core Web API 中使用Oracle数据库和Dapper看这篇就够了

    园子里关于ASP.NET Core Web API的教程很多,但大多都是使用EF+Mysql或者EF+MSSQL的文章.甚至关于ASP.NET Core Web API中使用Dapper+Mysql组 ...

  4. ASP.NET Core Web API使用静态swagger.json文件

    前言 ASP.NET Core Web API默认集成了Swashbuckle,可以在运行时显示Swagger UI: 而Swagger UI实际上是解析的动态生成的swagger.json: app ...

  5. NET问答: 如何在 ASP.NET Core Web API 的 Response 中添加自定义的 Header ?

    咨询区 JDawg: 我正在将 Web API 2 移植到 ASP.NET Core Web API 上,以前我都直接在 Response 属性上添加自定义的 Header,如下代码所示: HttpR ...

  6. ASP.NET Core Web API下事件驱动型架构的实现(二):事件处理器中对象生命周期的管理

    在ASP.NET Core Web API下事件驱动型架构的实现(一):一个简单的实现中,我介绍了事件驱动型架构的一种简单的实现,并演示了一个完整的事件派发.订阅和处理的流程.这种实现太简单了,百十行 ...

  7. core webapi缩略图_在ASP.NET Core Web API 项目里无法访问(wwwroot)下的文件

    新建 ASP.NET Core Web API 项目 -- RESTFul 风格 Hello World! 一.创建一个空项目 请查看 新建 .NET Core 项目 -- Hello World!  ...

  8. 使用Entity Framework Core,Swagger和Postman创建ASP.NET Core Web API的分步指南

    目录 介绍 背景 第1步:创建一个新项目 第2步:添加模型类 第3步:使用Entity Framework Core 第4步:添加数据库上下文和控制器 步骤5:在Package Manager控制台中 ...

  9. ASP.NET Core Web API 集成测试中使用 Bearer Token

    在 ASP.NET Core Web API 集成测试一文中, 我介绍了ASP.NET Core Web API的集成测试. 在那里我使用了测试专用的Startup类, 里面的配置和开发时有一些区别, ...

最新文章

  1. 转载:Objective-C中的 instancetype 和 id 关键字
  2. Javaweb-----HTTP协议
  3. CSS,让100%的宽度,自动减10,让100%的高度,自动减10,可以加减乘除
  4. css align-items的测试
  5. 【Java】用随机数打印hello world
  6. OpenShift 4 之通过直接访问内部的 Image Registry 操作容器镜像
  7. Spring AOP之通知类别
  8. java中osend,如何从java o javafx向windows任务栏发送信息
  9. python_tornado
  10. 图书管理系统完整代码
  11. 两款Java中小医院信息管理系统源码
  12. Facebook全新数字货币Libra引发关注 数字货币国际化逐渐发展
  13. 计算机操作系统学习笔记
  14. Windows --- 微信内网可用,但浏览器外网无法连接
  15. 大一训练赛-20180929-整套代码
  16. 理解jquery的$.extend()、$.fn和$.fn.extend()
  17. 2023最新完整版python安装教程
  18. 思科设备命令讲解(超基础)
  19. 阵列信号处理——LMS自适应波束形成算法
  20. Crypto++编译使用

热门文章

  1. 保证一个用户已选取的记录不被其他用户选取
  2. discord linux_如何在Discord中应用文本格式
  3. 修复windows脸部识别_如何在Windows 10中改善面部识别
  4. 中兴面试一个星期没有回音_如何在没有回声的情况下从亚马逊获取即时时尚建议...
  5. Mysql-高可用集群[MyCat中间件使用](三)
  6. 用websploit获取管理员后台地址
  7. oracle dba 手动创建数据实例
  8. Apache-Jmeter监控服务资源
  9. 《PowerShell 3.0 Advanced Admin handbook》已于今日上市
  10. 为or、in平反——or、in到底能不能利用索引?