(轉)WebApi自動生成在線文檔Swashbuckle


  原文地址:http://www.cnblogs.com/Arrays/p/5146194.html?utm_source=tuicool&utm_medium=referral

  

1.前言

1.1 SwaggerUI

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

1.2 Swashbuckle

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

2.版本和資源

你可以通過下列連接獲取相關說明。

Swashbuckle 項目地址:
https://github.com/domaindrivendev/Swashbuckle
swagger-ui 項目地址:
https://github.com/swagger-api/swagger-ui
swagger-ui 官網地址:
http://swagger.io/swagger-ui/

3.快速開始

  • WebAPI 安裝 Swashbuckle

    Install-Package Swashbuckle
  • 瀏覽器訪問

    http://<yourhostname>.com/swagger/ui/index
  • 如果不出意外則顯示
    運行截圖

    4.代碼注釋生成文檔說明。

    Swashbuckle 是通過生成的XML文件來讀取注釋的,生成 SwaggerUI,JSON 配置中的說明的。
    安裝時會在項目目錄 App_Start 文件夾下生成一個 SwaggerConfig.cs 配置文件,用於配置 SwaggerUI 相關展示行為的。如圖:

配置文件

將配置文件第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 文檔文件”

此處輸入圖片的描述

打開控制 "ValuesController" 添加注釋

using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Net.Http; using System.Web.Http; using ClassLibrary1; namespace WebApplication1.Controllers { [Authorize] public class ValuesController : ApiController { //some code..... /// <summary> /// 根據ID獲取一個值 /// </summary> /// <param name="id">值的ID</param> /// <remarks>當前方法根據ID獲取一個值</remarks> /// <returns>返回</returns> public string Get(int id) { return "value"; } // some code .... } } 

保存重寫生成. 如圖

此處輸入圖片的描述


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM