.net core8 使用Swagger(附當前源碼)

来源:https://www.cnblogs.com/cyzf/p/18410483
-Advertisement-
Play Games

說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...


說明

   該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。

    該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。

    說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。

有興趣的朋友,請關註我吧(*^▽^*)。

使用前提

1、Visual Studio使用2022版本

搭建項目

    OverallAuth2.0依然和OverallAuth1.0一樣,採用前後端分離模式,所以搭建後端,我們選擇  .net core web api(如下圖)

 

    選擇項目模板後,我們點擊【下一步】

 

選擇.net 8.0(最新長期支持版本),隨後創建項目

預設項目結構如下圖

 

直接運行,查看預設界面

 

    運行起來可以看到,系統預設的swagger界面非常簡介,也少了很多信息比如:

1、系統說明、版本、作者等。

2、介面的描述、參數等信息。

3、介面的分類等。

優化Swagger

    上面說道,系統預設的介面文檔是非常簡潔的,接下來我們在系統中,這樣做,讓swagger看起來更優美和專業。

 在項目下新增一個文件件PlugInUnit,然後再該文件夾下新建一個類SwaggerPlugInUnit

      建好SwaggerPlugInUnit後,在webapi同級建一個類庫Utility,用於存放系統的輔助工具等,然後再該類庫下建一個Enum文件夾,並新建ModeuleGroupEnum該枚舉。

如圖:

 

建好文件後,在ModeuleGroupEnum文件中寫一個枚舉SysMenu,並保存。
/// <summary>
/// 模塊分組
/// </summary>
public enum ModeuleGroupEnum
{
    SysMenu = 1,
}

隨後在SwaggerPlugInUnit中編寫一個方法,具體代碼如下

/// <summary>
/// swagger插件
/// </summary>
public static class SwaggerPlugInUnit
{
    /// <summary>
    /// 初始化Swagger
    /// </summary>
    /// <param name="services"></param>
    public static void InitSwagger(this IServiceCollection services)
    {
        //添加swagger
        services.AddSwaggerGen(optinos =>
        {
            typeof(ModeuleGroupEnum).GetEnumNames().ToList().ForEach(version =>
            {
                optinos.SwaggerDoc(version, new OpenApiInfo()
                {
                    Title = "許可權管理系統",
                    Version = "V2.0",
                    Description = "求關註,求一鍵三連",
                    Contact = new OpenApiContact { Name = "微信公眾號作者:不只是碼農   b站作者:我不是碼農呢", Url = new Uri("http://www.baidu.com") }
                });

            });

            //反射獲取介面及方法描述
            var xmlFileName = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
            optinos.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, xmlFileName), true);

        });
    }

    /// <summary>
    /// swagger加入路由和管道
    /// </summary>
    /// <param name="app"></param>
    public static void InitSwagger(this WebApplication app)
    {
        app.UseSwagger();
        app.UseSwaggerUI(options =>
        {
            typeof(ModeuleGroupEnum).GetEnumNames().ToList().ForEach(versoin =>
            {
                options.SwaggerEndpoint($"/swagger/{versoin}/swagger.json", $"介面分類{versoin}");
            });
        });
    }
}
然後再program中使用自定義swagger中間件

   做好以上步驟,我們的swagger基本算是搭建好了,只需要在控制器上方,添加路由和分組。

 /// <summary>
 /// 系統模塊
 /// </summary>
 [ApiController]
 [Route("api/[controller]/[action]")]
 [ApiExplorerSettings(GroupName = nameof(ModeuleGroupEnum.SysMenu))]

 

做完以上這些,我們對swagger就算優化完成,只需要運行系統,就可以查看效果

 

註意:必鬚生成介面的xml文件,不然會報錯。

 

  好了,以上就是搭建WebApi+優化Swagger的全部過程,你快來試試吧

如果對你有幫助,請關註我吧(*^▽^*)。

源代碼地址:https://gitee.com/yangguangchenjie/overall-auth2.0-web-api  

幫我Star,謝謝。

 

有興趣的朋友,請關註我吧(*^▽^*)。

關註我:一個全棧多端的寶藏博主,定時分享技術文章,不定時分享開源項目。關註我,帶你認識不一樣的程式世界


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

-Advertisement-
Play Games
更多相關文章
  • 在現代應用程式中,星級評分是一個常見的用戶界面元素,它允許用戶對產品、服務或內容進行評價。 想必大家在用各種帶有評分的軟體中看到過這個組件: 本文將指導你如何使用 Qml 創建一個簡單而美觀的星級評分組件,並且支持高度自定義。 ...
  • 在WPF開發中,經常會需要用到UI控制項的2D轉換(如:旋轉,縮放,移動,傾斜等功能),本文以一些簡單的小例子,簡述如何通過Transform類實現FrameworkElement對象的2D轉換,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 一:背景 講故事 公司部署在某碟上的項目在9月份壓測50併發時,發現某個容器線程、記憶體非正常的上漲,導致功能出現了異常無法使用。根據所學,自己分析了下線程和記憶體問題,分析時可以使用lldb或者windbg,但是個人比較傾向於界面化的windbg,所以最終使用windbg開乾。 二:WinDbg 分析 ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...