.NetCore2.1 WebAPI新增Swagger插件

来源:https://www.cnblogs.com/hunanzp/archive/2018/07/08/9279906.html
-Advertisement-
Play Games

說明 Swagger是一個WebAPI線上註解、調試插件,過去我們主要通過手工撰寫WebAPI介面的交互文檔供前端開發人員或外部開發者, 官網地址:https://swagger.io/。 但是在實際工作中,往往咋們的文檔工作通常落後於實際的環境,導致文檔和實際介面不一致,前後端開發人員苦不堪言。 ...


說明

Swagger是一個WebAPI線上註解、調試插件,過去我們主要通過手工撰寫WebAPI介面的交互文檔供前端開發人員或外部開發者,

官網地址:https://swagger.io/

但是在實際工作中,往往咋們的文檔工作通常落後於實際的環境,導致文檔和實際介面不一致,前後端開發人員苦不堪言。

Swagger的出現解放了介面文檔撰寫的麻煩也提高了前後端開發者的工作效率,所謂“工欲善其事,必先利其器 ”。現在讓咋們

瞭解下在.NET Core 2.1下如何實現Swagger。

 

1、Nuget安裝依賴包

 首先Nuget安裝Swashbuckle.AspNetCore

打開Nuget控制台(程式包管理控制台),鍵入下列命令

Install-Package  Swashbuckle.AspNetCore

2、添加Swagger中間件

public IServiceProvider ConfigureServices(IServiceCollection services)
        {
            services.Configure<CookiePolicyOptions>(options =>
            {
                // This lambda determines whether user consent for non-essential cookies is needed for a given request.
                options.CheckConsentNeeded = context => true;
                options.MinimumSameSitePolicy = SameSiteMode.None;
            });

            services.AddMvc().AddJsonOptions(options =>
            {
                //忽略迴圈引用
                options.SerializerSettings.ReferenceLoopHandling = ReferenceLoopHandling.Ignore;
                //不使用駝峰樣式的key
                options.SerializerSettings.ContractResolver = new DefaultContractResolver();
            })
            .SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

            // Register the Swagger generator, defining 1 or more Swagger documents
            services.AddSwaggerGen(c =>
            {
                c.SwaggerDoc("v1", new Info { Title = "My API", Version = "v1" });
            });
            return RegisterAutofac(services);//註冊Autofac
        }

  

 引用Swashbuckle.AspNetCore.Swagger,並啟用中間件

 1    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
 2         {
 3             if (env.IsDevelopment())
 4             {
 5                 app.UseDeveloperExceptionPage();
 6             }
 7             // Enable middleware to serve generated Swagger as a JSON endpoint.
 8             app.UseSwagger();
 9             // Enable middleware to serve swagger-ui (HTML, JS, CSS, etc.), 
10             // specifying the Swagger JSON endpoint.
11             app.UseSwaggerUI(c =>
12             {
13                 c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
14             });
15             app.UseVisitLogger();
16             app.UseMvc();
17         }

 

3、配置WebAPI項目屬性

1、雙擊Properties下的launchSettings.json,將launchUrl更新為swagger

 

F5結果如下:

 4、新增註解

如上圖,雖然WebAPI已經出來了,但是呢,並沒有發現我們在Action上寫的註釋? 老司機應該知道在Framework版本里我們需要

將WebAPI啟動項屬性里更改“項目生產“一欄中新增XML文檔,.NetCore也是如此。如下圖:

 

 保存後,按F5發現並木有生產註解,Why???  那是因為我們必須明確告訴Swagger應該從哪個路徑讀取WebAPI註解XML文件,更新Startup下的ConfigureServices。

參考下麵代碼:

           // Register the Swagger generator, defining 1 or more Swagger documents
            services.AddSwaggerGen(options =>
            {
                options.SwaggerDoc("v1", new Info { Title = "TestSystem", Version = "v1" });                
                //註入WebAPI註釋文件給Swagger      
                var xmlPath = Path.Combine(AppContext.BaseDirectory, "AirWebApi.xml");
                options.IncludeXmlComments(xmlPath);

                options.IgnoreObsoleteActions();
                ////options.IgnoreObsoleteControllers();
                //// 類、方法標記 [Obsolete],可以阻止【Swagger文檔】生成
                options.DescribeAllEnumsAsStrings();             
                options.OperationFilter<FormDataOperationFilter>();
            });

代碼不單單新增了註解,同時添加了阻止Swagger文檔生成的配置,通過讀取系統的[Obsolete]特性實現。

現在,讓我們再看看結果吧~

 

 是不是很爽~~

還有,Swagger是支持授權登錄的哦,這個待研究。

 


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

-Advertisement-
Play Games
更多相關文章
  • 題目背景 無 題目描述 在一個凹槽中放置了 n 層磚塊、最上面的一層有n 塊磚,從上到下每層依次減少一塊磚。每塊磚 都有一個分值,敲掉這塊磚就能得到相應的分值,如下圖所示。 如果你想敲掉第 i 層的第j 塊磚的話,若i=1,你可以直接敲掉它;若i>1,則你必須先敲掉第 i-1 層的第j 和第j+1 ...
  • 上一篇文章,學習了併發編程中的synchronized,這個比較好理解,也是我最初學習多線程編程中的一個簡單的實現的,大學的時候就會了,然後就一直以為多線程環境的同步只能通過這個來實現的,事實上Java還提供了另外一個更加輕量級的實現-volatile,如果說synchronized實現了數據在同一 ...
  • 1、存儲類 含義 描述變數空間開闢於記憶體中什麼地方,記憶體被分為棧、堆、數據段、bss段、text段等管理方法的記憶體段,變數空間開闢於這些段中。如局部變數(棧)、被顯示初始化為非0的全局變數和被初始化為非0的static局部變數(data段)、顯示初始化為0和沒有顯示初始化的全局變數(bss段) 2、 ...
  • javaDay01總結 1、主要學習內容: (1)java面向對象編程 (2)java圖形界面 (3)java資料庫編程 (4)java文件IO流 (5)java網路編程 (6)java多線程 2、java開發環境 JDK:包括JRE(java運行環境)、java工具(java編譯器javac.ex ...
  • 前言:反射(Reflection)是.NET提供給開發者的一個強大工具,儘管作為.NET框架的使用者,很多時候不會用到反射。但在一些情況下,尤其是在開發一些基礎框架或公共類庫時,使用反射會使系統架構更加靈活。 在開發中,我們常常會遇到比如有些狀態值在定義好後幾乎從不改動,這時候使用資料庫就顯得有些多 ...
  • 本篇描述一些常用的資料庫操作,包括:條件查詢、排序、分頁、事務等基本資料庫操作。試驗的資料庫為MySQL。 ...
  • 1、首先新建一個webAPI項目做為IdentityServer的服務端,提供生成Token的服務,首先修改Startup.cs文件,如下圖: 2、增加一個Config.cs文件,以便於提供資源和認證設置,如下圖: 3、在Startup.cs文件中配置做初始化: 4、好了,我們把網站啟動,然後我們訪 ...
  • 本文目標是指引從未使用過Linux的.Neter,如何在CentOS7上安裝.Net Core環境,以及部署.Net Core應用。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...