ASP.NET Core 2.2 系列【四】集成Swagger

来源:https://www.cnblogs.com/tenghao510/archive/2019/11/23/11918575.html
-Advertisement-
Play Games

Swagger 是一款自動生成線上介面文檔+功能測試功能軟體 一、安裝程式包 通過管理 NuGet 程式包安裝,搜索Swashbuckle.AspNetCore 二、配置 Swagger 將 Swagger 添加到 Startup.ConfigureServices 方法中的服務集合中: //註入S ...


Swagger

是一款自動生成線上介面文檔+功能測試功能軟體

一、安裝程式包

通過管理 NuGet 程式包安裝,搜索Swashbuckle.AspNetCore

二、配置 Swagger

將 Swagger 添加到 Startup.ConfigureServices 方法中的服務集合中:

            //註入Swagger服務
            services.AddSwaggerGen(c =>
            {
                    c.SwaggerDoc("v1", new Info { Title = "My API", Version = "v1" });
            });

在 Startup.Configure 方法中,啟用中間件為生成的 JSON 文檔和 Swagger UI 提供服務

            //啟用Swagger服務
            app.UseSwagger();
            app.UseSwaggerUI(c =>
            {
                c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
                c.DefaultModelsExpandDepth(-1); //設置為 - 1 可不顯示models
                c.DocExpansion(DocExpansion.None); //設置為none可摺疊所有方法
            });

 

運行項目,可在 http://localhost:<port>/swagger 瀏覽 API文檔,如下所示:

如果想把Swagger作為啟動頁面,可修改launchSettings.json,把  launchUrl設置為  swagger:

    "IIS Express": {
      "commandName": "IISExpress",
      "launchBrowser": true, //是否在瀏覽器中啟動
      "launchUrl": "swagger", //在瀏覽器中啟動的相對URL
      "environmentVariables": { //將環境變數設置為鍵/值對
        "ASPNETCORE_ENVIRONMENT": "Development"
      }

 

所有的Controller 的方法都是可以在 UI 上面進行測試。點擊方法可以展開對應的區域,點擊【Try it out】→ 【輸入參數】→ 點擊【Execute】。

三、可擴展性

Swagger 文檔信息和描述

修改AddSwaggerGen 方法,用來添加文檔信息。例如:作者,版權,描述。

            services.AddSwaggerGen(option =>
            {
                option.SwaggerDoc("v1", new Info
                {
                    Version = "v1",
                    Title = "線上介面文檔",
                    Description = "一個簡單的例子",
                    Contact = new Contact { Name = "TengHao", Email = "[email protected]" },
                    License = new License { Name = "博客地址", Url = "https://www.cnblogs.com/tenghao510/" }
                });
            });

 

下圖展示了 Swagger UI 顯示添加的版本信息。

XML註釋

【右鍵項目】→【屬性】→ 【生成】→ 【勾選XML 文檔文件】註意自己的路徑

修改AddSwaggerGen 方法。

備註:IncludeXmlComments方法中的includeControllerXmlComments參數控制是否顯示控制器註釋,預設是false。

            services.AddSwaggerGen(c =>
            {
                c.SwaggerDoc("v1", new Info
                {
                    Version = "v1",
                    Title = "線上介面文檔",
                    Description = "一個簡單的例子",
                    Contact = new Contact { Name = "TengHao", Email = "[email protected]" },
                    License = new License { Name = "TengHao", Url = "https://www.cnblogs.com/tenghao510/" }
                });
                // 為 Swagger JSON and UI設置xml文檔註釋路徑
                var basePath = Path.GetDirectoryName(typeof(Program).Assembly.Location);//獲取應用程式所在目錄
                var xmlPath01 = Path.Combine(basePath, "NetCoreWebApi.xml");
                c.IncludeXmlComments(xmlPath01, true);
                var xmlPath = Path.Combine(basePath, "NetCoreWebApi.Model.xml");
                c.IncludeXmlComments(xmlPath);
            });

 

運行項目,再看看效果:


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

-Advertisement-
Play Games
更多相關文章
  • 面試實習生的時候,當問到 is 和 == 的區別時,很多同學都答不上來,搞不清兩者什麼時候返回一致,什麼時候返回不一致。本文我們來看一下這兩者的區別。 我們先來看幾個例子: a = "hello" b = "hello" print(a is b) # 輸出 True print(a == b) # ...
  • 慕課網 2019年11月23日 300套 資料下載 百度網盤 百度網盤下載地址: 鏈接:https://pan.baidu.com/s/1rqn-PjqSO_xC2WSx1os6MQ 提取碼:npre 複製這段內容後打開百度網盤手機App,操作更方便哦 微雲地址: https://share.wei ...
  • 參考自《深入理解JAVA虛擬機》第二版 第2章 Java記憶體區域與記憶體溢出異常 2.1 概述 對於Java程式員來說,在虛擬機自動記憶體管理機制的幫助下,不再需要為每一個new操作去寫配對的delete/free代碼,由虛擬機管理記憶體這 一切看起來都很美好 ,一旦出現 記憶體泄漏和溢出方面 的問題,如果 ...
  • using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Diagnostics; namespac... ...
  • Windows Presentation Foundation(WPF)提供了一組服務,這些服務可用於擴展公共語言運行時(CLR)屬性的功能,這些服務通常統稱為WPF屬性系統。由WPF屬性系統支持的屬性稱為依賴項屬性(Dependency Property)。 基本上依賴屬性都支持綁定(Bindin ...
  • 為什麼要使用泛型倉儲?好處是? 前兩章在autofac註入的時候,用的User類作為例子,寫了增刪改查四個介面,也就是倉儲的GRUD。 當我們再添加一個實體(比如Student)時,StudentRepository跟UserRepository代碼幾乎一樣的代碼,重覆量很大,為了減少冗餘、提高工作 ...
  • I had validated in .net 4.8 NewtonSoft.Json's speed rank 1st,System.Text.Json.JsonSerializer.Serialize 2nd,and BinaryFormatter 3rd. ...
  • MiniProfiler 是一款性能分析的輕量級程式,可以基於action(request)記錄每個階段的耗時時長,還是可以顯示訪問資料庫時的SQL(支持EF、EF Code First)等 一、安裝程式包 通過Nuget安裝MiniProfiler : Install-Package MiniPr ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...