日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

.NET Core 3.0 使用Nswag生成Api文档和客户端代码

發布時間:2023/12/4 asp.net 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 .NET Core 3.0 使用Nswag生成Api文档和客户端代码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

摘要

在前后端分離、Restful API盛行的年代,完美的接口文檔,成了交流的紐帶。在項目中引入Swagger (也稱為OpenAPI),是種不錯的選擇,它可以讓接口數據可視化。下文將會演示

  • 利用Nswag如何生成Api文檔

  • 利用NSwagStudio如何生成客戶端代碼,并且進行測試

什么是 Swagger/OpenAPI?

Swagger 是一個與語言無關的規范,用于描述 REST API。Swagger 項目已捐贈給 OpenAPI 計劃,現在它被稱為開放 API。這兩個名稱可互換使用,但 OpenAPI 是首選。它允許計算機和人員了解服務的功能,而無需直接訪問實現(源代碼、網絡訪問、文檔)。其中一個目標是盡量減少連接取消關聯的服務所需的工作量。另一個目標是減少準確記錄服務所需的時間。

Nswag VS Swashbuckle?

.NET Swagger 實現類庫有兩個比較流行:

  • Swashbuckle.AspNetCore 是一個開源項目,用于生成 ASP.NET Core Web API 的 Swagger 文檔。

  • NSwag 是另一個用于生成 Swagger 文檔并將 Swagger UI 或 ReDoc 集成到 ASP.NET Core Web API 中的開源項目。此外,NSwag 還提供了為 API 生成 C# 和 TypeScript 客戶端代碼的方法。

為什么我在.NET core3.0中選擇NSwag呢,因為Swashbuckle目前不在維護了,而NSwag比較活躍,一直在更新,功能也很強大,可以完美的代替Swashbuckle.AspNetCore具體可以參考:https://github.com/aspnet/AspNetCore.Docs/issues/4258

一、利用Nswag生成Api文檔

步驟
  • 創建Asp.NET?Core Api項目,并且集成NSwag

  • 配置項目

  • 運行項目

  • 創建Asp.NET?Core Api項目,并且集成NSwag

    我們將簡單的創建一個ASP.NET core API項目。將其命名為“WebAPIwithSwg”。基于.NETcore3.0

    安裝nuget包NSwag.AspNetCore

    接下來,在Startup.cs文件中配置Nswag服務和中間件。

    在ConfigureServices方法中添加服務

    public void ConfigureServices(IServiceCollection services)
    {
    services.AddControllers();
    services.AddSwaggerDocument(); //注冊Swagger 服務
    }
    在Configure方法中添加Nswag中間件
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
    if (env.IsDevelopment())
    {
    app.UseDeveloperExceptionPage();
    }
    app.UseRouting();
    app.UseAuthorization();
    app.UseEndpoints(endpoints =>
    {
    endpoints.MapControllers();
    });
    app.UseOpenApi(); //添加swagger生成api文檔(默認路由文檔 /swagger/v1/swagger.json)
    app.UseSwaggerUi3();//添加Swagger UI到請求管道中(默認路由: /swagger).
    }
    配置項目

    運行項目

    右鍵項目在瀏覽器中查看,查看swagger UI需要在url后面添加“/swagger”。本示例http://localhost:54117/swagger

    二、利用NSwagStudio如何生成客戶端代碼,并且進行測試
    提供GUI界面是NSwag的一大特點,只需要下載安裝NSwagStudio,即可生成客戶端代碼。
    步驟
  • 現在安裝NSwagStudio

  • NSwagStudio配置,生成客戶端代碼

  • 創建測試客戶端項目

  • 下載安裝NSwagStudio

    下載NSwag Studio?http://rsuter.com/Projects/NSwagStudio/installer.php?安裝之后打開 NSwag Studio 如圖

    NSwagStudio配置,生成客戶端代碼

    選擇runtime,我選擇的是NETCORE30,切換OpenAPI/Swagger?Specification?,在Specification URL 輸入你的Swagger.json路徑,本示例:http://localhost:54117/swagger/v1/swagger.json輸入路徑之后,點擊 create local copy 按鈕獲取json。

    接下配置來生成客戶端代碼。我們首先選擇“csharp client”復選框,然后勾選掉 “Inject Http Client via Constructor (life cycle is managed by caller)” ,最后設置下輸出路徑 點擊生成文件(Generate Files)。步驟如下

    到此客戶端代碼已經自動生成。

    查看生成的部分代碼

    public async System.Threading.Tasks.Task<System.Collections.Generic.ICollection<WeatherForecast>> GetAsync(System.Threading.CancellationToken cancellationToken) { var urlBuilder_ = new System.Text.StringBuilder(); urlBuilder_.Append(BaseUrl != null ? BaseUrl.TrimEnd('/') : "").Append("/WeatherForecast"); var client_ = new System.Net.Http.HttpClient(); try { using (var request_ = new System.Net.Http.HttpRequestMessage()) { request_.Method = new System.Net.Http.HttpMethod("GET"); request_.Headers.Accept.Add(System.Net.Http.Headers.MediaTypeWithQualityHeaderValue.Parse("application/json")); PrepareRequest(client_, request_, urlBuilder_); var url_ = urlBuilder_.ToString(); request_.RequestUri = new System.Uri(url_, System.UriKind.RelativeOrAbsolute); PrepareRequest(client_, request_, url_); var response_ = await client_.SendAsync(request_, System.Net.Http.HttpCompletionOption.ResponseHeadersRead, cancellationToken).ConfigureAwait(false); try { var headers_ = System.Linq.Enumerable.ToDictionary(response_.Headers, h_ => h_.Key, h_ => h_.Value); if (response_.Content != null && response_.Content.Headers != null) { foreach (var item_ in response_.Content.Headers) headers_[item_.Key] = item_.Value; } ProcessResponse(client_, response_); var status_ = ((int)response_.StatusCode).ToString(); if (status_ == "200") { var objectResponse_ = await ReadObjectResponseAsync<System.Collections.Generic.ICollection<WeatherForecast>>(response_, headers_).ConfigureAwait(false); return objectResponse_.Object; } else if (status_ != "200" && status_ != "204") { var responseData_ = response_.Content == null ? null : await response_.Content.ReadAsStringAsync().ConfigureAwait(false); throw new ApiException("The HTTP status code of the response was not expected (" + (int)response_.StatusCode + ").", (int)response_.StatusCode, responseData_, headers_, null); } return default(System.Collections.Generic.ICollection<WeatherForecast>); } finally { if (response_ != null) response_.Dispose(); } } } finally { if (client_ != null) client_.Dispose(); } }
    創建測試客戶端項目

    創建一個控制程序項目,命名“WebApiClient”。

    把自動生成的類“WeatherForecastClient”添加到客戶端項目中,然后安裝Newtonsoft

    最后在Main函數中添加測試代碼,開始使用Api。

    static async System.Threading.Tasks.Task Main(string[] args)
    {

    var weatherForecastClient = new WeatherForecastClient();
    //gets all values from the API
    var allValues = await weatherForecastClient.GetAsync();
    Console.WriteLine("Hello World!");
    }

    運行客戶端應用程序,進行調用api

    當然如果需要調試api項目內部代碼,可以設置斷點,進入一步一步的調試

    小結:NSwag 功能遠不止這些,本篇文章演示了如何生成api文檔和自動生成的api客戶端代碼方便我們調試,也可以作為對應的sdk。

    參考:微軟官方文檔---https://docs.microsoft.com/zh-cn/aspnet/core/tutorials/getting-started-with-nswag?view=aspnetcore-2.2&tabs=visual-studio

    總結

    以上是生活随笔為你收集整理的.NET Core 3.0 使用Nswag生成Api文档和客户端代码的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。