前後端分離中台框架 Admin.Core 學習-介紹與配置說明

来源:https://www.cnblogs.com/morang/archive/2023/08/20/admin_core_book_01.html
-Advertisement-
Play Games

## 中台框架後端項目 Admin.Core 的介紹與配置說明 > 中台admin是前後端分離許可權管理系統,Admin.Core為後端項目,基於.NET 7.0開發。 > 支持多租戶、數據許可權、動態 Api、任務調度、OSS 文件上傳、滑塊拼圖驗證、多資料庫,分散式緩存、分散式事務等 - 項目地址 ...


中台框架後端項目 Admin.Core 的介紹與配置說明

中台admin是前後端分離許可權管理系統,Admin.Core為後端項目,基於.NET 7.0開發。
支持多租戶、數據許可權、動態 Api、任務調度、OSS 文件上傳、滑塊拼圖驗證、多資料庫,分散式緩存、分散式事務等

  • 項目地址
  • 技術棧
    • dotnet7
    • FreeSql
    • Autofac
    • CAP
    • Mapster
  • 特點
    • 快速啟動,上手簡單
    • 系統模塊化
    • Swagger的模塊化封裝
    • 讀寫分離
    • 分庫分表
    • 分散式事務 TCC/ SAGA
    • 動態API
    • 系統許可權封裝基本滿足大部分項目
    • 多租戶實現
  • 開發環境
    • Vs2022
    • dotnet7
  • 項目結構
    • hosts
      • ZhonTai.Host:預設啟動項目,添加對 ZhonTai.Admin.Dev,模塊的引用,並將程式集配置到 assemblyNames
    • platform
      • ZhonTai.Admin 核心服務
      • ZhonTai.ApiUI 介面文檔封裝,分模塊載入
      • zhonTai.Common 通用庫封裝
      • ZhonTai.DynamicApi 動態WebApi庫
      • ZhonTai.Admin.Dev 代碼生成器添加
    • tests
      • ZhonTai.Tests 測試庫
    • modules
      • XX.XX 我準備放自己的模塊

框架的使用

1. 從GitHub 克隆/下載項目

  • 後端:git clone https://github.com/zhontai/Admin.Core.git
  • 前端:git clone https://github.com/zhontai/admin.ui.plus.git

2. 後端項目的啟動

使用新下的VS2022打開後,預設啟動項目 ZhonTai.Host ,直接Ctrl+F5運行即可
系統將會根據實體生成資料庫及表,並根據 Configs/dbconfig.json 配置將 initData/*.json 的數據生成到本地Sqlite中
(ps:第一次搞dotnet7的項目,vs2019+自己下SDK折騰半天搞不了一點,需要vs2022 17.4+)

3. 配置文件說明

  • launchSettings.json

    • 預設本地啟動配置
      • 配置項
        • 運行環境
          • ASPNETCORE_ENVIRONMENT:Development
        • 啟動埠
          • 預設:8000
          • 優先順序低於appconfig.urls的配置
  • appsettings.{Env}.json

    • 預設的應用配置文件
    • 配置項
      • 日誌等級
        • 預設:Information
      • 跨域
        • 預設:*
      • CAP配置
        • 預設:未啟用
      • 滑動驗證碼
        • 預設:300s有效期
        • 是否開啟在appconfig.json配置varifyCode.enable
  • Configs*.{Env}.json

    • 自定義的應用配置文件
    • dbconfig.json
      • 資料庫配置
      • 綁定模型
        • 單例:DbConfig
      • 配置項
        • 支持類型:type
          • 預設:Sqlite
            MySql = 0, SqlServer = 1, PostgreSQL = 2,Oracle = 3, Sqlite = 4, OdbcOracle = 5,OdbcSqlServer = 6, OdbcMySql = 7,OdbcPostgreSQL = 8, Odbc = 9, OdbcDameng =10, MsAccess = 11, Dameng = 12,OdbcKingbaseES = 13, ShenTong = 14,KingbaseES = 15, Firebird = 16
        • 連接字元串:connectionString
          • 預設:admindb.db
        • 同步結構
          • syncStructure:true
            • 預設啟用
            • 分散式部署需要註意關閉
          • 監聽同步結構腳本 syncStructureSql:false

          將會輸出codeFirst執行的腳本
          將 assemblyNames 配置的所有實體執行結構移 db.CodeFirst.SyncStructure 
          1.創建臨時表
          2.插入歷史數據,修改欄位名稱情況註意
          3.刪除舊表,重命名臨時表為新表
          生產上該自己執行腳本的還是自己執行

        • 同步數據
          • syncData:true
          • sysUpdateData:false
            • 同步更新數據
            • 確定要修改表數據是最新數據再開啟,除localdb測試就不要使用
          • syncDataIncludeTables:[]
            • 同步數據包含表,指定表同步,不填同步所有表
          • syncDataExcludeTables:[]
            • 同步數據排除表,指定表不同步
          • syncDataUser
            • 同步數據操作用戶
          • syncDataPath
            • 不配置預設為  項目目錄/InitData/Admin
            • 預設會將文件夾下的所有 表名.json 添加到數庫中,預設新增所有數據
            • 如果是租戶數據,格式為 表.tenant.json
          • syncDataCurd:false
            • 監聽同步數據Curd操作

          設置是否將syncDataPath文件夾下的 表名.json 加/修改到資料庫中

        • 生成數據
          • generateData:true
            預設開啟但無效,需要將禁用創建資料庫及禁用步:createDb:false && syncData:false
          • 加了視圖菜單就可以使用這個功能來創建生成預設數據
  • cacheconfig.json

    • 緩存配置,未綁定模型,redis緩存,限流參數配置
    • 配置項
      • 支持類型
        • 預設:Memory
        • Memory = 0,Redis = 1
      • 限流緩存類型
        • 預設:Memory
        • Memory = 0,Redis = 1
      • Redis配置
        • 127.0.0.1:6379
  • appconfig.json

    • 應用配置
    • 綁定模型
      • 單例: AppConfig
    • 配置項
      • appType 應用程式類型
        • 預設:Controllers
        • Controllers ControllersWithViews MVC
      • urls 啟動地址
        • http://*:8000
      • corUrls 跨域
        • []
      • assemblyNames 程式集名稱
        • ZhonTai.Admin
        • Mapster自動註冊程式集
      • tenantc租戶
        • true
      • distributeKey 分散式事務唯一標識
        • 為空則不生成分散式事務表
      • validate 驗證開關
        • 登錄,介面許可權,數據許可權驗證
      • swagger Swagger文檔s
      • apiUI 介面文檔地址
      • MiniProfiler 性能分析器
        • false
      • identityServer 統一認證授權伺服器
        • false
      • aop 面向切麵編程s
        • 開啟事務
      • log 資料庫日誌
        • 操作日誌
      • rateLimit 限流開關
        • false
      • varifyCode 登錄驗證碼
        • true
      • defaultPassword 預設密碼
        • 111111
      • dynamicApi 動態api
        • 結果格式化
      • passwordHasher 標準標識密碼哈希
        • 啟用後相同密碼加密後各不相同
      • maxRequestBodySize 最大請求大小
        • 104857600
      • healthChecks 健康檢查
        • enable:true 啟用
        • path:/admin/health
  • jwtconfig.json

    • JWT配置
    • 綁定模型
      • 單例:JwtConfig
    • 配置項
      • issuer 發行者
      • audience 訂閱者
      • securityKey 密鑰
      • expires 有效期(分鐘) 120
      • refreshExpires 刷新有效期(分鐘) 1440
  • ossconfig.json

    • 本地上傳配置
    • 綁定模型
      • IOptions<OSSConfig>
    • OSS配置
      • Minio
      • 阿裡雲
      • 騰訊雲
      • 七牛
      • 華為雲
  • uploadconfig.json

    • 上傳配置
    • 綁定模型
      • IOptions<UploadConfig>
  • ratelimitconfig.json

    • 限流配置
    • 綁定模型
      • IOptions
    • 支持類型
      • IP限流
        • 預設未啟用
        • 需要在appconfig.json中配置rateLimit:true生效
        • 使用Redis實現限流
        • 需要在cacheconfig.json中配置typeRateLimit
  • InitData\模塊*.{tenant}.json

    • 預設初始化數據

寫在最後

文章的起因是想找個不錯的框架用來搞個自己用的系統,找了幾個dotnet+vue的框架,zhontai的這個是看到上手最容易,前後臺的代碼也沒有封裝得太深,二開也很方便,看著用著都挺舒服的。
唯一的不足就是文檔了,一點資料都找不到,就只能一點點看代碼,然後邊看邊記錄,以備後用,又想著既然都寫了,那就再整理一下了,順便分享出來咯,希望能夠對後面使用框架的有所幫助。

作者:易墨
Github:yimogit
純靜態工具站點:metools
說明:歡迎拍磚,不足之處還望園友們指出;
迷茫大概是因為想的太多做的太少。


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

-Advertisement-
Play Games
更多相關文章
  • # 網路編程 ## 一、概述 網路編程是指編寫運行在多個設備(電腦)的程式,這些設備都通過網路連接起來。 ### 電腦網路 把分佈在不同地理區域的電腦與專門的外部設備用通信線路互連成一個規模大,功能強的網路系統, 從而使眾多的電腦可以方便地互相傳遞信息,共用硬體,軟體,數據信息等資源。 ## ...
  • 在Python中,元組(Tuple)是一種有序且不可變的數據類型。元組可以包含任意數量的元素,用逗號分隔,並用圓括弧括起來。與列表(List)不同,元組的元素不能修改。元組與列表一樣,可以通過索引訪問其中的元素。 ```python my_tuple = ("apple", "banana", "c ...
  • OpenAI的Karpathy利用周末搞了一個迷你Llama2項目llama2.c用500行C語言實現無任何依賴項的推理程式,此項目在github發佈以來衍生出了基於各種語言的迷你Llama推理實現llama2.go、llama2.java、llama2.py等等; 但該項目原本的模型並不支持中文, ...
  • # wangyi > 記錄一次某大廠筆試的AC過程 ![image-20230820152914557](https://img2023.cnblogs.com/blog/2862884/202308/2862884-20230820160050687-208549606.png) ``給定一個二維 ...
  • ## 一,下載安裝相關 ### 1,這個軟體什麼作用? Anaconda:Python大禮包(包含解析器,一系列庫,軟體包管理器Conda) 主要作用,不用配庫,如果需要庫a,anaconda會把庫a相關的依賴庫一併打包下載 次要作用,可以同時安裝不同版本的python,和對應依賴庫,相互隔離。 # ...
  • [TOC] # 本篇前瞻 好的,現在你已經來到一個新的小結,在這裡你將學習到go語言的重要內容,習得go 25個關鍵字中的12個:var, const, if, else, switch, case, default, fallthrough, for, break, goto, continue, ...
  • GitHub的Codespaces為個人用戶提供了免費的4核8G伺服器資源,今天就來實戰如何用桌面版vscode連接codespace伺服器做遠程開發,把編譯運行下載等耗時耗資源的操作都轉移到雲端進行,還能為應用創建各種docker服務,這都不要錢! ...
  • 先決條件 Visual Studio 2019 v16.9 預覽版1或更高版本(通過WSL可選組件進行.NET調試)。若要檢查 WSL 組件,請選擇 “工具” > “獲取工具和功能” 。 在 Visual Studio 安裝程式中,選擇 “單個組件”,然後鍵入 “WSL” 搜索安裝組件 。 安裝WS ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...