ASP.NET Core中使用Swagger

来源:https://www.cnblogs.com/green-jcx/archive/2022/04/15/16150176.html
-Advertisement-
Play Games

在實際的軟體開發過程中,我們通常會採用一種前後端分離的開發模式,在這種模式下一般會由前後端兩類開發人員協同開發,在這種情況下後端開發人員則需要提供API文檔去與前端人員進行對接,這樣才能保障後續的工作能夠順利開展。 並且當前項目在與外部系統進行業務往來或者數據交互的時候,我們通常會作為“介面方”對外 ...


在實際的軟體開發過程中,我們通常會採用一種前後端分離的開發模式,在這種模式下一般會由前後端兩類開發人員協同開發,在這種情況下後端開發人員則需要提供API文檔去與前端人員進行對接,這樣才能保障後續的工作能夠順利開展。

 

並且當前項目在與外部系統進行業務往來或者數據交互的時候,我們通常會作為“介面方”對外提供數據,這種情況下我們通常也會需要後端開發人員去針對介面編寫API文檔。另外,在API介面開發完成後,我們的測試人員還要單獨下載第三方介面測試工具對API介面進行測試。

 

那麼基於以上的應用場景的痛點,本文將推薦一個既方便又美觀的介面文檔框架——Swagger。

使用 Swagger 後,項目可以直接通過API代碼生成文檔,不再需要自己手動編寫介面文檔,對開發者來說非常方便,以此便可節約寫文檔的時間去產出更多的東西。不光如此,Swagger 還提供 Web 頁面,可線上測試 API的共,參數和格式都定好了,直接在界面上輸入對應的值,即可線上測試介面。


 1.使用Swagger

通常在項目中引用Swagger組件有兩種方式:一種是直接在網上下載到對應的類庫文件,另一種是通過NuGet包進行添加。下麵主要介紹如何通過NuGet進行引用。

 

1.1.引用程式集

針對要引用的項目按滑鼠右鍵,在彈出的菜單中單擊“管理NuGet程式包”,此時會彈出一個管理界面,然後在界面中切換到“瀏覽”選項卡頁,在搜索欄中搜索“Swashbuckle.Asp.NetCore”,然後選中搜索到的結果,在右側單擊“安裝”按鈕。

在安裝之後我們可以通過右側的“解決方案資源管理器”中查看項目對應的依賴項是否已經包含Swagger的包,並且通過下方的輸出視窗中看到,已經成功引入了6個程式集文件:

 

 1.2.配置Swagger服務

打開Startup.cs類,找到ConfigureServices方法,添加配置Swagger服務的代碼:

 1 public void ConfigureServices(IServiceCollection services)
 2 {
 3     services.AddControllers();
 4     
 5     #region 配置Swagger服務
 6         services.AddSwaggerGen(c =>
 7                                {
 8                                    c.SwaggerDoc("v1", new OpenApiInfo
 9                                                 {
10                                                     Version = "v1.0",
11                                                     Title = "SwaggerShow",
12                                                     Description = "介面說明文檔",
13                                                     Contact = new OpenApiContact { Name = "張三", Email = "[email protected]" }
14                                                     
15                                                 }); ; //END SwaggerDoc()
16                                    
17                                }); // END AddSwaggerGen() 
18     #endregion
19         
20         }

1.3.配置中間件

在Startup.cs類的Configure方法中,配置兩個中間件分別是:UseSwagger和UseSwaggerUI

 1    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
 2         {
 3             if (env.IsDevelopment())
 4             {
 5                 app.UseDeveloperExceptionPage();
 6             }
 7 
 8             #region 配置Swagger中間件
 9             app.UseSwagger();
10             app.UseSwaggerUI(c =>
11             {
12                 c.SwaggerEndpoint("swagger/v1/swagger.json", "v1");
13             }); 
14             #endregion
15 
16             app.UseRouting();
17 
18             app.UseAuthorization();
19 
20             app.UseEndpoints(endpoints =>
21             {
22                 endpoints.MapControllers();
23             });
24         }

1.4.查看效果

在配置好Swagger的服務和中間件後,我們就可以啟動項目,然後在瀏覽器中輸入此格式的URL:IP:埠號/swagger,按下回車便可以看到Swagger界面了。


 2.介面文檔配置為項目首頁

通常我們的項目啟動會訪問預設的登錄頁或首頁,但在開發和測試的過程中,我們為了方便可以將Swagger介面文檔設置為我們項目的首頁(啟動頁),這個時候我們就不必在瀏覽器中單獨輸入“/swagger”的標識了。方式如下:

 

1.將“launchSetting.json”文件中的“launchUrl”屬性刪除。

 2.在Startup.cs類的Configure方法中找到UseSwaggerUI的配置,並對其加入一個RoutePrefix屬性,將其賦值為空字元。

 


 3.Swagger中的介面添加註釋

要為介面添加註釋信息首先要找到介面對應的控制器(Controller),並直接在控制器(Controller)中對控制器類或方法添加註釋信息即可。

 

添加玩註釋信息之後,接下來就需要把註釋信息在Swagger中展示。Swagger中介面對應的註釋信息是通過一個XML文件進行維護的。

因此我們需要對項目配置一個用於存儲Swagger介面註釋信息的XML文件,方法如下:

  1. 在解決資源管理器中找到web項目,通過滑鼠右擊的菜單中打開“屬性”界面。
  2. 在“屬性”界面左側欄點擊“生成”,在“生成”下找到“輸出”。
  3. 勾選“輸出”板塊下的“文檔文件”覆選框。(這裡演示的環境是VS2022,在其他VS中勾選“XML文檔文件”)。
  4. 勾選後會彈出文本框讓你選擇一個XML文件的生成路徑,如果使用預設位置,可不填寫路徑。如果要自定義填寫,推薦填寫相對路徑。

在配置XML文檔文件後,則還需要在Startup類的ConfigureServices方法中,對Swagger服務配置部分,增加對XML文件的引用代碼,修改後的代碼如下:

 1    public void ConfigureServices(IServiceCollection services)
 2         {
 3             services.AddControllers();
 4 
 5             #region 配置Swagger服務
 6             services.AddSwaggerGen(c =>
 7             {
 8                 c.SwaggerDoc("v1", new OpenApiInfo
 9                 {
10                     Version = "v1.0",
11                     Title = "SwaggerShow",
12                     Description = "介面說明文檔",
13                     Contact = new OpenApiContact { Name = "張三", Email = "[email protected]" }
14 
15                 }); ; //END SwaggerDoc()
16 
17                 var basePath = AppContext.BaseDirectory;
18                 var xmlPath = Path.Combine(basePath, "SwaggerShow.xml");
19                 c.IncludeXmlComments(xmlPath, true);
20 
21             }); // END AddSwaggerGen() 
22             #endregion
23 
24         }

修改代碼之後,啟動項目就可以看到介面相應的註釋信息了。


4.對Swagger中的Model添加註釋

作為一個標準化的介面文檔,只針對介面部分添加註釋信息肯定是不夠的,我們還需要為介面所涉及到的“Model”添加註釋。具體的實現也很簡單,大致和上面添加介面註釋信息的方式相同,這裡不在過多使用圖例展示,而只是通過文字進行描述:

  1. 為實體類Model添加註釋信息。
  2. 仿照上面添加介面註釋的方式,為“Model實體類”所在項目(模型層)配置添加一個XML文檔文件。
  3. 仿照上面添加介面註釋的方式,在ConfigureServices方法中對Swagger的服務配置增加對XML文件的引用代碼。
 1   public void ConfigureServices(IServiceCollection services)
 2         {
 3             services.AddControllers();
 4 
 5             #region 配置Swagger服務
 6             services.AddSwaggerGen(c =>
 7             {
 8                 c.SwaggerDoc("v1", new OpenApiInfo
 9                 {
10                     Version = "v1.0",
11                     Title = "SwaggerShow",
12                     Description = "介面說明文檔",
13                     Contact = new OpenApiContact { Name = "張三", Email = "[email protected]" }
14 
15                 }); ; //END SwaggerDoc()
16 
17                 var basePath = AppContext.BaseDirectory;
18                 var xmlPath = Path.Combine(basePath, "SwaggerShow.xml");
19                 c.IncludeXmlComments(xmlPath, true); //介面註釋信息                       
20                 c.IncludeXmlComments(Path.Combine(basePath, "SwaggerModel.xml"), true); //Model註釋信息
21 
22             }); // END AddSwaggerGen() 
23             #endregion
24 
25         }

添加完成之後的效果如圖:

 


 5.去掉Swagger警告提示

我們在為Swagger中的介面或Model添加註釋信息後,會有一個現象:那就是項目下的所有類型或成員,都出現警告提示要求添加註釋信息。

如果不想添加註釋,又不想看到這個警告提示,可以這樣做:在項目中單擊滑鼠右鍵,選擇“屬性”命令,然後在彈出的視窗中找到“生成”下的“錯誤和警告”,併在其下的“取消顯示警告”的文本框中添加“;1591”,然後重新生成項目即可。


6.忽略API

在我們的介面中可能存在一些不想對外公開的介面或介面的某個方法,對於這種情況我們可以在介面對於的Controller上或者Action上,增加特性“[ApiExploreSettings(IgnoreAPI)]”進行忽略,添加後對應的方法或介面就不會出現在Swagger文檔中了。

 

知識改變命運
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 大家平時都會用到哪些可視化的工具呢?Python中又有哪些好用的可視化模塊呢?今天就給大家分享一個Python小技能,小白也 能學會的可視化教程。 正 文 今天小編總結歸納了若幹個常用的可視化圖表,並且通過調用plotly、matplotlib、altair、bokeh和seaborn等模塊來分 別 ...
  • 最近在工作中面向社群玩家組織了一場活動,需要進行隨機抽獎,參考之前小明大佬的案例,再結合自己的需求,做了一個簡單的隨機抽獎小工具。 今天我就來順便介紹一下這個小工具的製作過程吧! 1. 核心功能設計 針對隨機抽獎的小工具,需要可以導入參與抽獎的人員名單,然後選擇不同的獎勵類型進行隨機抽取獲獎名單並導 ...
  • 大家在Debug程式的時候,是否遇到過因為“下一步”按太快,而導致跳過了想要深入分析的那段代碼?是不是很想要有“回到上一步”這樣的操作呢? 在IDEA中就提供了一個幫助你回退代碼的機會,但這個方法並不是萬能的。好了,下麵就來具體說說這個功能的使用! 使用Reset Frame回退操作 不知道你在De ...
  • 修飾類只有public和default(也就是是不寫訪問修飾符) 修飾成員變數或成員方法時有四種 public 可以被任意包中的類訪問 protected 可以被同一包下的其他類訪問(包括同一包下的子類),其他包的子類可以訪問 default(也就是什麼都不寫) 可以被同一包下的其他類訪問(包括同一 ...
  • 來源:juejin.im/post/5d026212f265da1b8608828b IDEA是Java開發利器,springboot是Java生態中最流行的微服務框架,docker是時下最火的容器技術,那麼它們結合在一起會產生什麼化學反應呢? 一、開發前準備 1.Docker安裝 可以參考: ht ...
  • 之前用.net5.0寫webapi,自動集成swagger,非常方便。asp.net mvc沒有自動集成swagger,但是手動配置swagger也很簡單。 1、nuget引用Swashbuckle庫,安裝完後,App_Start下自動多了一個SwaggerConfig.cs; 2、打開Swagge ...
  • 1. DevOps的一些介紹 DevOps(Development和Operations的組合詞)是一組過程、方法與系統的統稱,用於促進開發(應用程式/軟體工程)、技術運營和質量保障(QA)部門之間的溝通、協作與整合。 它是一種重視“軟體開發人員(Dev)”和“IT運維技術人員(Ops)”之間溝通合 ...
  • 工具 這裡用到兩個工具分別為Procdump+Windbg Procdump:ProcDump是一個命令行實用工具,主要目的是監視應用程式,以便在管理員或開發人員可用於確定峰值的原因期間監視 CPU 峰值和生成故障轉儲。 ProcDump 還包括使用視窗掛起 (使用相同的視窗掛起定義,Windows ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...