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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

如何使 WebAPI 自动生成漂亮又实用在线API文档

發(fā)布時間:2023/12/4 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何使 WebAPI 自动生成漂亮又实用在线API文档 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1.前言

1.1?SwaggerUI

SwaggerUI?是一個簡單的Restful API 測試和文檔工具。簡單、漂亮、易用(官方demo)。通過讀取JSON 配置顯示API. 項目本身僅僅也只依賴一些 html,css.js靜態(tài)文件. 你可以幾乎放在任何Web容器上使用。

1.2?Swashbuckle

Swashbuckle?是.NET類庫,可以將WebAPI所有開放的控制器方法生成對應(yīng)SwaggerUI的JSON配置。再通過SwaggerUI?顯示出來。類庫中已經(jīng)包含SwaggerUI?。所以不需要額外安裝。

2.快速開始

  • 創(chuàng)建項目?OnlineAPI來封裝百度音樂服務(wù)(示例下載) ,通過API可以搜索、獲取音樂的信息和播放連接。

我盡量刪除一些我們demo中不會用到的一些文件,使其看上去比較簡潔。

  • WebAPI 安裝?Swashbuckle

    Install-Package Swashbuckle
  • 代碼注釋生成文檔說明。
    Swashbuckle?是通過生成的XML文件來讀取注釋的,生成?SwaggerUI,JSON 配置中的說明的。
    安裝時會在項目目錄 App_Start 文件夾下生成一個 SwaggerConfig.cs 配置文件,用于配置?SwaggerUI?相關(guān)展示行為的。如圖:

  • 將配置文件大概99行注釋去掉并修改為

c.IncludeXmlComments(GetXmlCommentsPath(thisAssembly.GetName().Name));
  • 并在當前類中添加一個方法

    /// <summary>/// </summary>/// <param name="name"></param>/// <returns></returns>protected static string GetXmlCommentsPath(string name){ return string.Format(@"{0}\bin\{1}.XML", AppDomain.CurrentDomain.BaseDirectory, name); }
  • 緊接著你在此Web項目屬性生成選卡中勾選 “XML 文檔文件”,編譯過程中生成類庫的注釋文件

  • 添加百度音樂 3個API

  • 訪問?http://<youhost>/swagger/ui/index,最終顯示效果

  • 我們通過API 測試API 是否成功運行

3.添加自定義HTTP Header

在開發(fā)移動端 API時常常需要驗證權(quán)限,驗證參數(shù)放在Http請求頭中是再好不過了。WebAPI配合過濾器驗證權(quán)限即可

首先我們需要創(chuàng)建一個 IOperationFilter 接口的類。IOperationFilter

在 SwaggerConfig.cs 的 EnableSwagger 配置匿名方法類添加一行注冊代碼

c.OperationFilter<HttpHeaderFilter>();

添加Web權(quán)限過濾器

在你想要的ApiController 或者是 Action 添加過濾器

[AccessKey]

最終顯示效果

4.顯示上傳文件參數(shù)

SwaggerUI 有上傳文件的功能和添加自定義HTTP Header 做法類似,只是我們通過特殊的設(shè)置來標示API具有上傳文件的功能

在 SwaggerConfig.cs 的 EnableSwagger 配置匿名方法類添加一行注冊代碼

c.OperationFilter<UploadFilter>();

API 文檔展示效果

5.版本和資源

你可以通過下列連接獲取相關(guān)說明。
OnlineAPI Demo 項目下載
OnlineAPI Demo下載
Swashbuckle 項目地址:
https://github.com/domaindrivendev/Swashbuckle
swagger-ui 項目地址:
https://github.com/swagger-api/swagger-ui
swagger-ui 官網(wǎng)地址:
http://swagger.io/swagger-ui/


相關(guān)文章:

  • WebAPI前置知識:HTTP與RestfulAPI

  • WEB API系列(一):WEB API的適用場景、第一個實例

  • WEB API 系列(二) Filter的使用以及執(zhí)行順序

  • ASP.NET Web API 安全篩選器

  • Web API 基于ASP.NET Identity的Basic Authentication

  • ASP.NET Web Api使用CacheCow和ETag緩存資源

  • 使用 West Wind WebSurge 對 ASP.NET Web API 服務(wù)進行壓力測試

  • Web API應(yīng)用支持HTTPS的經(jīng)驗總結(jié)

  • Dion Hinchcliffe談Web API的過去與未來

  • WebAPI生成可導(dǎo)入到PostMan的數(shù)據(jù)


原文地址:http://www.cnblogs.com/Arrays/p/5146194.html


.NET社區(qū)新聞,深度好文,微信中搜索dotNET跨平臺或掃描二維碼關(guān)注

贊賞

人贊賞

總結(jié)

以上是生活随笔為你收集整理的如何使 WebAPI 自动生成漂亮又实用在线API文档的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。