ASP.NET Core Web API中使用Swagger

来源:https://www.cnblogs.com/lucky_hu/archive/2019/07/04/11130209.html
-Advertisement-
Play Games

本節導航 Swagger介紹 在ASP.NET CORE 中的使用swagger   在軟體開發中,管理和測試API是一件重要而富有挑戰性的工作。在我之前的文章 "《研發團隊,請管好你的API文檔》 " 也專門闡述了通過文檔管理工具,來保證API文檔和代碼的一致性,這樣更加有助於 ...



本節導航

  • 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.AspNetCoreNSwag這兩個包來實現Swagger,而且二者都是github上開源的。此外,nswag還提供了生成typescript客戶端代碼的方法以及用於API的服務代碼。

1.2 TPL

  任務並行庫(TPL)是System.Threading和System.Threading.Tasks命名空間中的一組公共類型和API。

  TPL動態地擴展併發度,以最有效地使用所有可用的處理器。通過使用TPL,您可以最大限度地提高代碼的性能,同時專註於您的代碼的業務實現。

  從.NET Framework 4開始,TPL是編寫多線程和並行代碼的首選方式。

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"));
            });
        }

使用場景

參考

關註
  請關註微信公眾號智客坊

使用場景


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、基礎案例 1、基礎案例概覽 歷時一個半月,SpringBoot2.0基礎案例的文章基本更新完畢了,基礎案例包含了SpringBoot的基礎教程,高級應用,日誌配置,資料庫使用,事務管理等。關於SpringBoot2.0的基礎案例就更新到這裡了,後續會更新SpringBoot2.0和各種中間件的整 ...
  • 單列集合框架體系 List 集合體系 主要實現類 依次為 ArrayList,LinkedList,Vector 。 List介面主要特征: 有序,可重覆,有索引,底層容量是動態擴容的。(代碼以JDK 1.8為例) ArrayList:是List介面的主要實現類,底層用數組實現: ,transien ...
  • 簡介: 使用Springboot應用,選中需要的模塊, Spring已經預設將場景配置好了,只需在配置文件中少量配置就可以運行起來 自己編寫業務代碼 自動配置原理 這個場景Springboot幫我們配置了什麼、能不能修改呢?能修改哪些配置? xxxxxAutoConfiguration :幫我們給容 ...
  • 占位符% %s (str類型占位) %d(digit,int類型占位) 案例: name = input('請輸入您的姓名:') age = input('您的年齡:') job = input('您的工作:') hobbie = input('您的愛好:') mag = ''' info of % ...
  • 項目地址: "https://github.com/PythonerKK/django generate pdf/tree/master" 這個demo實現了通過用戶輸入自己的個人信息生成一份簡歷pdf,來闡述如何使用Django的HttpResponse生成PDF的文檔。 先上效果圖: 安裝依賴庫 ...
  • 有限狀態自動機(FSM):是一種表達某一狀態到另一狀態發生轉化的數學模型。 例如:在長跑比賽開始時 我處於等待的狀態下,待裁判喊 預備 時,我就會從等待狀態轉換到預備狀態。聽到裁判的槍聲時,我就從預備狀態轉換到奔跑狀態 。這個過程就相當於有限狀態自動機。 FSM的狀態就是一個事件當前所處於的情況。 ...
  • [toc] Django 使用 markdown 插件 Python Markdown 插件 安裝 1 將 markdown 轉化為 html models templates: 此時,模板中通過 將 中的 markdown 文本轉化為 html 在前臺頁面顯示。 2 使用 markdown 編輯框 ...
  • 7.2 繼承與派生 7.21繼承 1、什麼是繼承? 繼承是一種新建類的的方式,在python中支持一個子類繼承多個父類。新建的類稱為子類或者派生類,父類又可以稱為基類或者超類,子類會”遺傳“父類的屬性。 2、為什麼要用繼承 減少代碼冗餘 3、繼承是類與類之間的關係,尋找這種關係需要先抽象再繼承 7. ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...