中台框架后端项目 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的这个是看到上手最容易,前后台的代码也没有封装得太深,二开也很方便,看着用着都挺舒服的。

唯一的不足就是文档了,一点资料都找不到,就只能一点点看代码,然后边看边记录,以备后用,又想着既然都写了,那就再整理一下了,顺便分享出来咯,希望能够对后面使用框架的有所帮助。

前后端分离中台框架 Admin.Core 学习-介绍与配置说明的更多相关文章

  1. 一套.NET Core +WebAPI+Vue前后端分离权限框架

    今天给大家推荐一个基于.Net Core开发的企业级的前后端分离权限框架. 项目简介 这是基于.NetCore开发的.构建的简单.跨平台.前后端分离的框架.此项目代码清晰.层级分明.有着完善的权限功能 ...

  2. JEECG前后端分离UI框架实战版本抢先体验(ng2-admin+Angular4+AdminLTE+WebStorm)

    JEECG前后端分离UI框架实战版本 - 抢先体验 (ng2-admin+Angular4+AdminLTE) 关键词: ng2-admin.Angular4.AdminLTE.Nodejs.Jeec ...

  3. JEECG前后端分离UI框架实战抢先体验(ng2-admin+Angular4+AdminLTE+WebStorm)

    JEECG前后端分离UI框架 (ng2-admin+Angular4+AdminLTE) 关键词: ng2-admin.Angular4.AdminLTE.Nodejs.Jeecg JEECG紧跟技术 ...

  4. 【开源】【前后端分离】【优雅编码】分享我工作中的一款MVC+EF+IoC+Layui前后端分离的框架——【NO.1】框架概述

    写博客之前总想说点什么,但写的时候又忘了想说点什么,算了,不说了,还是来送福利吧. 今天是来分享我在平时工作中搭建的一套前后端分离的框架. 平时工作大多时候都是在做管理类型的软件开发,无非就是增.删. ...

  5. thinkphp 前后端分离

    thinkphp 前后端分离 简单记录一下之前学习tp的历程吧. 前端HTML页面渲染 <?php namespace app\index\controller; use think\Contr ...

  6. 基于 koajs 的前后端分离实践

    一.什么是前后端分离? 前后端分离的概念和优势在这里不再赘述,有兴趣的同学可以看各个前辈们一系列总结和讨论: 系列文章:前后端分离的思考与实践(1-6) slider: 淘宝前后端分离实践 知乎提问: ...

  7. shiro vue 前后端分离中模拟登录遇到的坑

    系统采用jeeplus框架(ssm+redis+shiro+mongodb+redis),默认是了JSP未做前后端分离,由于业务需要已经多终端使用的需求(H5.小程序等),需要实现前后端分离.但是由于 ...

  8. 前后端分离项目获取后端跨控制器获取不到session

    最近做前后端分离项目(.net core web api  +vue)时,后台跨控制器不能获取到session.由于配置的是共享的session.本来以为是共享session出了问题,就在共享sess ...

  9. 采用异步来实现重新连接服务器或者重新启动服务 C#中类的属性的获取 SignalR2简易数据看板演示 C#动态调用泛型类、泛型方法 asp .net core Get raw request. 从壹开始前后端分离[.NetCore 不定期更新] 38 ║自动初始化数据库

    采用异步来实现重新连接服务器或者重新启动服务 开启异步监听,不会导致主线程的堵塞,在服务异常断开后一直检测重新连接服务,成功连接服务后通知各个注册的客户端! #region 检测断线并重连OPC服务 ...

  10. ASP.NET Core模块化前后端分离快速开发框架介绍之2、快速创建一个业务模块

    源码地址 GitHub:https://github.com/iamoldli/NetModular 演示地址 地址:https://nm.iamoldli.com 账户:admin 密码:admin ...

随机推荐

  1. 2021-01-21:java中,HashMap的读流程是什么?

    福哥答案2020-01-21: jdk1.7读流程:1.key是否为空值null,如果为空,直接遍历table[0]链表,寻找key==null键.调用的是getForNullKey()方法.如下:1 ...

  2. 2021-02-14:假设有排成一行的N个位置,记为1~N,N 一定大于或等于 2,开始时机器人在其中的M位置上(M 一定是 1~N 中的一个)。如果机器人来到1位置,那么下一步只能往右来到2位置;如果机器人来到N位置,那么下一步只能往左来到 N-1 位置;如果机器人来到中间位置,那么下一步可以往左走或者往右走;规定机器人必须走 K 步,最终能来到P位置(P也是1~N中的一个)的方法有多少种?

    2021-02-14:假设有排成一行的N个位置,记为1~N,N 一定大于或等于 2,开始时机器人在其中的M位置上(M 一定是 1~N 中的一个).如果机器人来到1位置,那么下一步只能往右来到2位置:如 ...

  3. [学习笔记]解决因C#8.0的语言特性导致EFCore实体类型映射的错误

    今天下午在排查一个EF问题时,遇到了个很隐蔽的坑,特此记录. 问题 使用ef执行Insert对象到某表时报错,此对象的Address为空: 不能将值 NULL 插入列 'Address',表 'dbo ...

  4. 深入了解Js中的对象

    在JavaScript中,对象是个无序的键值对数据集.例如: var xiaoqiang={ name:"wangqiang", age:30, city:"guangz ...

  5. springboot 整合jdbc

    在springboot底层无论关系型还是非关系型数据库都是用spring-data进行交互 新建: 通过spring initialer勾选重要依赖jdbc api和mysql driver: 源码分 ...

  6. Cobalt Strike 连接启动教程(1)

      第一步:把cobaltstrike4(解压后)拷贝到虚拟机Kali系统的root目录下 第二步:进入cobalstrike4文件夹中 第三步:选寻kali系统 IP地址 第四步: 启动服务端:(t ...

  7. Cobalt Strike 连接启动教程,制作图片🐎(2)

    扫描有两种方式:arp 和 icmp 查看进程列表 攻击----生成后门-----Payload 可以生成各类语言免杀牧马---(输出:选择C或者python或者php) go.咕.com 生成c语言 ...

  8. RocketMQ 顺序消费机制

    顺序消息是指对于一个指定的 Topic ,消息严格按照先进先出(FIFO)的原则进行消息发布和消费,即先发布的消息先消费,后发布的消息后消费. 顺序消息分为分区顺序消息和全局顺序消息. 1.分区顺序消 ...

  9. 2023-06-22:一所学校里有一些班级,每个班级里有一些学生,现在每个班都会进行一场期末考试 给你一个二维数组 classes ,其中 classes[i] = [passi, totali] 表

    2023-06-22:一所学校里有一些班级,每个班级里有一些学生,现在每个班都会进行一场期末考试 给你一个二维数组 classes ,其中 classes[i] = [passi, totali] 表 ...

  10. 9. SpringMVC处理ajax请求

    9.1.@RequestBody @RequestBody 可以获取请求体信息,使用@RequestBody 注解标识控制器方法的形参,当前请求的请求体就会为当前注解所标识的形参赋值 <!--此 ...