.Net Core 分散式微服務框架 - Jimu 添加 Swagger 支持

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

系列文章 1. ".Net Core 分散式微服務框架介紹 Jimu" 2. ".Net Core 分散式微服務框架 Jimu 添加 Swagger 支持" 一、前言 最近有空就優化 "Jimu" (一個基於.Net Core 的分散式微服務框架),考慮到現在的開發組織都向前後端分離發展,前後端各司 ...


系列文章

  1. .Net Core 分散式微服務框架介紹 - Jimu
  2. .Net Core 分散式微服務框架 - Jimu 添加 Swagger 支持

一、前言

最近有空就優化 Jimu (一個基於.Net Core 的分散式微服務框架),考慮到現在的開發組織都向前後端分離發展,前後端各司其職,好的 api 文檔可以減少大家溝通的時間成本,所以優先給 Jimu 添加對 api 文檔生成的支持。市面上非常著名和牛逼的的 api 文檔生成框架非 swagger 莫屬。 它可以用來生成、描述、調用可視化的 Web 服務。花了 二天多的時間把它集成到 Jimu 的 apigateway。

如圖

api 列表

api 明細

二、使用方式

1. 環境

  • Net Core 2.0
  • 基於Jimu 框架的 ApiGateway

2. 添加引用


Install-Package Jimu.Client.ApiGateway.SwaggerIntegration

3. 啟動代碼

在 Startup 里添加 UseJimuSwagger()


        public void ConfigureServices(IServiceCollection services)
        { 
            services.UseJimuSwagger(); // 添加 Swagger 支持 
        }
 
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {  
            app.UseJimuSwagger(); // 添加 Swagger 支持

     

4. 定義介面(服務/方法)

介面定義可以添加三種標註,這些標註最終會顯示在 swagger 生成的文檔。

a. JimuService 標註是對介面元數據的定義和描述,如創建人、時間、描述、訪問角色限制等。
b. JimuFieldComment 標註是對形式參數的註釋。
c. JimuReturnComment 標註是對介面的返回類型做註釋。


        [JimuService(EnableAuthorization = true, CreatedBy = "grissom", CreatedDate = "2018-07-17", Comment = "根據新聞 id 獲取新聞內容")]
        [JimuFieldComment("id", "新聞id")]
        [JimuReturnComment("一篇新聞內容")]
        News GetNews(string id);

5. 定義對象 (DTO)

如果介面參數或返回類型是一個用戶定義的類,對應的屬性也可以添加註釋標註 JimuFieldComment, 這些標註最終會顯示在 swagger 生成的文檔。

    public class News
    {
        [JimuFieldComment("新聞id")]
        public string Id { get; set; }
        [JimuFieldComment("新聞標題")]
        public string Title { get; set; }
        [JimuFieldComment("作者")]
        public string Director { get; set; }
        [JimuFieldComment("發佈時間")]
        public string PostTime { get; set; }
        [JimuFieldComment("新聞內容")]
        public string Content { get; set; }

    }

三、圖解

四、總結

支持開源是很累和很耗時間的活,不過開源過程中自己也學到很多知識,希望可以一直堅持下去。

五、源碼

https://github.com/grissomlau/jimu

https://github.com/grissomlau/jimu.demo


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

-Advertisement-
Play Games
更多相關文章
  • 果然,在犯困的時候就該寫寫博客,寫博客就不困了,哈哈! 上篇我記錄了自己的SqlHelper的開發過程,今天記錄一下如何使用這個sqlhelper書寫一個具有簡單增刪改查的小實例啦。 實例描述:在資料庫新建一張TbClass表,將表的內容讀取到一個DataGridView上,並且可以在winform ...
  • c#中的對象大體分為值類型和引用類型,值類型大致包括 int, string, struct等,引用類型大致包括 自定義Class,object 等。 值類型直接存儲對象,而引用類型存儲對象的地址,在對引用類型進行複製的時候,也只是複製對象的地址。 完全複製一個引用類型對象主要有幾種方法: 1.額外 ...
  • 之前在Asp.net MVC + Angular1 的項目中,要調試前臺代碼都是用瀏覽器的開發者工具,使用正常,也沒有感覺太大的不方便。 後來接觸Angular2項目,因為它是要經過編譯的,所以在瀏覽器中看到的代碼並不是我們寫的代碼,這就很不方便調試了。 下麵開始試驗: 1.我用常規方法創建一個An ...
  • c#常用數據結構解析 http://blog.csdn.net/suifcd/article/details/42869341談談在平時使用U3D時經常用到的數據結構和各種數據結構的應用場景吧。1.幾種常見的數據結構 這裡主要總結下小匹夫在工作中常碰到的幾種數據結構:Array,ArrayList, ...
  • 寫在前面 整個項目都托管在了 Github 上: 查找更為方便的版本見:https://alg4.ikesnowy.com/ 這一節內容可能會用到的庫文件有 Quick,同樣在 Github 上可以找到。 善用 Ctrl + F 查找題目。 習題&題解 2.3.1 題目 按照 Partition() ...
  • 和老公結婚已經有三年了,從當時的熱戀到今天的不太交流,三年的時間我們從轟轟烈烈的戀愛到了今天過著平淡如水的日子。說句實話走到今天也實在是不太容易,有了孩子,有了車子和房子,卻再也不願意理對方,而這一切皆因為微信這個應用軟體的出現。 自從微信出現以後,老公每天下班再也不照看孩子,而他喜歡做的事情就是拿 ...
  • Partial關鍵詞定義的類可以在多個地方被定義,最後編譯的時候會被當作一個類來處理。 首先看一段在C 中經常出現的代碼,界面和後臺分離,但是類名相同。 public partial class Form1 : Form { public Form1() { InitializeComponent( ...
  • 博客園潛水了有兩年多,現在想分享一個可以說是幫助類吧。 我們在編寫程式的過程中,經常會用到一些方法,我只是把這些方法整合一下,方便使用,目前有md5,sha1,aes加解密,身份證驗證,敏感詞過濾,文件壓縮,圖片與base64互相轉換,時間戳與時間互相轉換,簡單的http請求,簡單的ftp上傳下載, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...