Web Api 2.0中使用Swagger生成Api文檔的2個小Tips

来源:http://www.cnblogs.com/lwqlun/archive/2017/12/07/7998523.html
-Advertisement-
Play Games

當Web Api 2.0使用OAuth2授權時,如何在Swagger中添加Authorization請求頭? Swagger說明文檔支持手動調用Api, 但是當Api使用OAuth2授權時,由於沒有地方可以輸入授權Token, 導致響應結果一直是401沒有授權。 解決方案: 在Swagger配置文件 ...


 

當Web Api 2.0使用OAuth2授權時,如何在Swagger中添加Authorization請求頭?

Swagger說明文檔支持手動調用Api, 但是當Api使用OAuth2授權時,由於沒有地方可以輸入授權Token, 導致響應結果一直是401沒有授權。

 

 

解決方案:

在Swagger配置文件中,添加對請求頭中Authorization的設置。

 

1. 在Api項目中添加一個新類AddAuthorizationHeader並實現IOperationFilter介面

 

    

    public class AddAuthorizationHeader : IOperationFilter
    {
        /// <summary>
        /// Adds an authorization header to the given operation in Swagger.
        /// </summary>
        /// <param name="operation">The Swashbuckle operation.</param>
        /// <param name="schemaRegistry">The Swashbuckle schema registry.</param>
        /// <param name="apiDescription">The Swashbuckle api description.</param>
        public void Apply(Operation operation, SchemaRegistry schemaRegistry, ApiDescription apiDescription)
        {
            if (operation == null) return;

            if (operation.parameters == null)
            {
                operation.parameters = new List<Parameter>();

            }


            var parameter = new Parameter
            {
                description = "Token",
                @in = "header",
                name = "Authorization",
                required = true,
                type = "string"
            };


            if (apiDescription.ActionDescriptor.GetCustomAttributes<AllowAnonymousAttribute>().Any())
            {
                //如果Api方法是允許匿名方法,Token不是必填的

                parameter.required = false;
            }

            operation.parameters.Add(parameter);
        }
    }

 

2. 在SwaggerConfig.cs中啟用Authorization請求頭。

 

        public static void Register(HttpConfiguration config)
        {
            var thisAssembly = typeof(SwaggerConfig).Assembly;

            config.EnableSwagger(c =>
            {

                c.OperationFilter<AddAuthorizationHeader>();

                c.SingleApiVersion("v1", "EHealthCareClinic.WebApi");

                c.IncludeXmlComments(GetXmlCommentsPath());
            })
            .EnableSwaggerUi(c =>
            {
            });
        }

 

 

3. 編譯Api項目,重新打開Swagger說明文檔, Parameters列表中就會出現Authorization變數,錄入正確的授權Token,  401未授權問題消失。

 

當Web Api 2.0使用IHttpActionResult作為返回值時,如何在Swagger中生成Response Class範例?

IHttpActionResult是Web Api 2.0引入的介面。

使用IHttpActionResult作為Api  返回值的好處。

  • 簡化對控制器的單元測試
  • 創建Http響應的通用邏輯被移動到單獨的類中
  • 通過隱藏構建相應的底層細節,使控制器動作更清晰

 

Swagger生成文檔的原理是通過讀取Web Api項目生成的XML文檔說明文件,使用反射技術,動態展示每個Action方法的方法簽名。

 

但是當使用IHttpActionResult作為Api方法返回值之後,Swagger不能通過反射正確讀取到返回值的類型,所以導致生成的文檔缺少。

 

例:

 

        /// <summary>
        /// 獲取省份列表
        /// <param name="countryId">國家ID</param>
        /// </summary>
        [HttpGet]
        [Route("countries/{countryId}/provinces")]
        public IHttpActionResult GetProvinceList(Guid countryId)
        {
            var result = QueryService.GetProvinceCollection(new CountryId(countryId));
            return Ok(result);
        }

 

 

解決方案:

Web Api 2.0中引入了一個新的特性類System.Web.Http.Description.ResponseTypeAttribute。

這個特性類構造只有一個參數,即返回值的類型。

我們只需要在每個Api方法簽名處使用這個新特性聲明Api返回值的類型, Swagger生成的說明文檔中就會出現返回類型的說明。

 

        /// <summary>
        /// 獲取省份列表
        /// <param name="countryId">國家ID</param>
        /// </summary>
        [HttpGet]
        [Route("countries/{countryId}/provinces")]
        [ResponseType(typeof(IEnumerable<EHealthCareClinic.Business.QueryModel.ProvincePresentation>))]
        public IHttpActionResult GetProvinceList(Guid countryId)
        {
            var result = QueryService.GetProvinceCollection(new CountryId(countryId));
            return Ok(result);
        }

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 調試步驟 遠程伺服器: 1.找到本地vs安裝目錄,Enterprise\Common7\IDE目錄下的Remote Debugger整個文件夾複製到遠程伺服器 2.根據伺服器的系統類型,選擇其中的x64或x86文件夾,以管理員身份運行msvsmon.exe 3.將vs生成的項目文件發佈到遠程伺服器, ...
  • 1 //定義一個委托 2 static Func delFunc = (a, b) => 3 { 4 Console.WriteLine("委托線程:" + Thread.CurrentThread.ManagedThreadId); 5 return (a + b).ToString(); 6 }... ...
  • NPOI版本:2.2.1.0 最近公司有這樣的需求: 統計每個部門下麵,多個費用使用情況。部門存在多級,但統計時,只需統計到2級,2級以下的,歸到第2級的部門下。並且要求,第2級部門有個小計,第1級部門需要有個合計。最後,還需提供總計。 本來對NPOI研究的還不夠深入的,以前都是直接通過別人提供的代 ...
  • 很多人一開始學習.net 第一天必定是安裝Visual studio 或者很多關於C#學習的書上第一章節必定是告訴你要你下載一個vs 其實沒有vs未必就不能開發了,只是可能說vs給我的開髮帶來了很多的便捷,但是作為初學者一開始就用它,可能會導致你忽略 了很多原理性的東西 , 一般在windowxp以 ...
  • 1 //==>自建線程 2 new Thread(() => 3 { 4 //線程任務 5 Console.WriteLine(Thread.CurrentThread.ManagedThreadId); 6 }).Start(); 7 8 9 //==>線程池管理線程(不知道線程任務用時,不能控制... ...
  • 數據表格能夠清晰的呈現數據信息,但是我們對於一些繁雜多變的數據想要很直觀的看到數據變化走勢或者數據的占比時,數據圖表會更具代表性,並且在呈現數據信息上也更形象,也能獲取更多純數字信息所不能直接展現的信息。在下麵的代碼中,將向您展示如何通過使用免費的Free Spire XLS for .NET組件來 ...
  • 1.父類必須包含構造函數麽? 父類必須要有一個構造函數,有參無參都可以。 構造函數是對象的基本,沒有構造函數就沒有對象,若父類中顯示的有參數的構造函數,在子類繼承就必須寫一個構造函數來調用父類的構造函數。 如果父類中有沒有參數的構造函數,在子類中可以不顯示的寫父類的構造函數,系統會自動調用沒有參數的 ...
  • 前段時間,Insus.NET有實現一組字元串在輸出時,靠左或靠右對齊。《輸出的字元靠右對齊》http://www.cnblogs.com/insus/p/7953304.html 現在Insus.NET參考此方法,實一張塔松葉,實現之前,先練習一下,輸出半張: public void WriteTr ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...