Admin.NET

基于.NET 的通用管理平台
授权协议 Apache
开发语言 C# TypeScript
所属分类 Web应用开发、 后台管理系统(模板)
软件类型 开源软件
地区 国产
投 递 者 姚德容
操作系统 未知
开源组织
适用人群 未知
 软件概览

Admin.NET 是基于.NET 5/6 实现的通用管理平台。整合最新技术,模块插件式开发,前后端分离,开箱即用。

  • 后台基于Furion框架,vue2前端基于小诺框架,vue3前端基于Vben-Admin框架。
  • 集成EF Core、多租户、缓存、数据校验、鉴权、事件总线、动态API、通讯、远程请求、任务调度、gRPC等众多黑科技。
  • 核心模块包括:用户、角色、职位、组织机构、菜单、字典、日志、多应用管理、文件管理、定时任务等功能。
  • 代码简洁、易扩展,让开发更简单、更通用、更流行!
如果对您有帮助,点击右上角⭐Star⭐关注 ,感谢支持开源!

Stargazers over time

�� 框架拓展包

更新不及时,建议使用源码

包类型 名称 版本 描述
Furion.Extras.Admin.NET nuget Admin.NET 核心包
可自行按照 Furion 框架脚手架初始化工程,然后引用此包即可,其他层配置见源代码。��此包会紧跟Furion版本更新而更新。

�� 框架脚手架

模板类型 名称 版本 描述
Furion.Admin.NET.Template.App nuget Admin.NET 框架模板
打开 CMD 或 Powershell 执行dotnet命令

1、安装脚手架
dotnet new --install Furion.Admin.NET.Template.App

2、更新脚手架
dotnet new --install Furion.Admin.NET.Template.App

3、使用脚手架(生成之后推荐将所有的 nuget 包更新到最新版本)
dotnet new Admin.NET -n 你的项目名称

其实安装之后可以直接在VS里面进行可视化及创建工程

�� �� 模块/插件化开发

  • 按照 Furion 框架脚手架或者本框架脚手架初始化工程。
  • 创建自己业务的 Dll 插件库工程,引用 Furion.Extras.Admin.NET 包,编写自己的业务代码包括实体、服务等。
  • 在 XXX.Web.Entry 层里面的 appsettings.json 配置此插件 Dll 的路径。配置文档说明
  • 此时框架和自己业务实体可以同时做数据迁移,耦合度最低。也可以自行将数据库分系统库、业务库等。
  • 将自己业务前端代码包括view和api文件复制到前端工程相应目录即可。

仓库内 plugin 文件内为本框架模块/插件开发事例,供参考。

�� 插件市场

欢迎大家勇于参与开源,贡献自己的应用插件,你我都可以做到,.NET正在迅速崛起,我们都是历史的见证人��

【核酸采集系统】

�� 前后端一体化

将后台提供的Swagger接口直接生成对应前端的API文件,前端再也不需要手撸一个个的对应后后的API定义了。后台接口更新后,只需要重新生成一遍覆盖即可。

详细教程见群里面视频文件【Fur课堂_20201028前后端(第1部份).mp4】、【Fur课堂_20201028前后端(第2部份).mp4】

增加了Vue3.0、Vite、Antd、TypeScript模式的UI框架,希望大家来一来完善各页面应用,感谢������

�� 衍生版本

Admin.NET】隆重推出SqlSugar版本

如果集成其他ORM,请参照各自操作使用说明。系统默认EFCore不会处理其他ORM实体等,请自行处理。

�� 多租户简介

框架目前采用基于共享数据库TenantId的方式实现,后期可无缝迁移转换到基于多库或者Schema模式。

  • 平台超管对租户进行增删改查操作,对各租户进行权限(菜单)的分配,租户管理员密码默认123456
  • 租户管理员根据平台分配的权限再对本租户内用户进一步权限划分
  • 针对新开发的业务功能,平台超管可以针对性分配给各租户(比如某租户购买后才有此功能菜单等)

�� 更新日志

更新日志 点击查看

�� 在线体验

  • 开发者租户:用户名:superAdmin,密码:123456
  • 公司1租户: 公司1租户管理员(用户名:zuohuaijun@163.com 密码:123456),公司1租户普通用户(用户名:dilon@163.com 密码:123456)

�� 快速启动

需要安装:VS2019(最新版)、npm或yarn(最新版)

  • 启动后台:打开backend/Admin.NET.sln解决方案,直接运行(F5)即可启动(数据库默认SQLite)
  • 启动前端:VSCode或HBuilder,打开frontend文件夹,进行依赖下载,运行npm install或yarn命令,再运行npm run serve或 yarn run serve
  • 浏览器访问:http://localhost:81 (默认前端端口为:81,后台端口为:5566)

�� 分层说明

├─Admin.NET.Application             ->业务应用层,在此写您具体业务代码
├─Admin.NET.Core                    ->框架核心层
├─Admin.NET.Database.Migrations     ->架构维护层,主要存放迁移中间文件
├─Admin.NET.EntityFramework.Core    ->EF Core配置层,主要配置数据库及相关
├─Admin.NET.Web.Core                ->Web核心层,主要是服务注册及鉴权
├─Admin.NET.Web.Entry               ->Web入口层/启动层,可任意更换
├─Furion.Extras.Admin.NET           ->封装的框架核心层,已做成NuGet包
注:源码直接开发建议自己的业务代码直接写在【Admin.NET.Application】层里面,可随框架升级减少冲突。或直接用模板脚手架创建自己的工程。

�� 帮助文档

��后台文档:

��前端文档:

  1. Ant Design Pro of Vue 使用文档 https://pro.antdv.com/docs/getting-started
  2. Ant Design of Vue 组件文档 https://www.antdv.com/docs/vue/getting-started-cn/
  3. Vue 开发文档 https://cn.vuejs.org/v2/guide/

��快捷部署到 linux 文档:

��代码生成器使用教程:

��fork项目后该这样做后续开发:

��关于signalr使用:

��通读以上文档,您就可以玩转本项目了(其实您已经是高手了)。项目使用上的问题,文档中基本都可以找到答案。

�� 效果图

�� 详细功能

  1. 主控面板、控制台页面,可进行工作台,分析页,统计等功能的展示。
  2. 用户管理、对企业用户和系统管理员用户的维护,可绑定用户职务,机构,角色,数据权限等。
  3. 应用管理、通过应用来控制不同维度的菜单展示。
  4. 机构管理、公司组织架构维护,支持多层级结构的树形结构。
  5. 职位管理、用户职务管理,职务可作为用户的一个标签,职务目前没有和权限等其他功能挂钩。
  6. 菜单管理、菜单目录,菜单,和按钮的维护是权限控制的基本单位。
  7. 角色管理、角色绑定菜单后,可限制相关角色的人员登录系统的功能范围。角色也可以绑定数据授权范围。
  8. 字典管理、系统内各种枚举类型的维护。
  9. 访问日志、用户的登录和退出日志的查看和管理。
  10. 操作日志、用户的操作业务的日志的查看和管理。
  11. 服务监控、服务器的运行状态,CPU、内存、网络等信息数据的查看。
  12. 在线用户、当前系统在线用户的查看。
  13. 公告管理、系统的公告的管理。
  14. 文件管理、文件的上传下载查看等操作,文件可使用本地存储,阿里云oss,腾讯cos接入,支持拓展。
  15. 定时任务、定时任务的维护,通过cron表达式控制任务的执行频率。
  16. 系统配置、系统运行的参数的维护,参数的配置与系统运行机制息息相关。
  17. 邮件发送、发送邮件功能。
  18. 短信发送、短信发送功能,可使用阿里云sms,腾讯云sms,支持拓展。

�� 数据库操作

本框架ORM默认采用EF Core开发,加上拓展比如SqlSugar,理论上兼容并支持所有类型数据库。��

【MySQL】

  1. Admin.NET.EntityFramework.Core 项目安装 Pomelo.EntityFrameworkCore.MySql,Nuget 需安装 5.0 版本 (支持 MySql 5.x +) MySql.EntityFrameworkCore:支持 (MySql 8.x +)
  2. DefaultDbContext.cs 指定 DbProvider , [AppDbContext("DefaultConnection", DbProvider.MySql)]
  3. dbsettings.json 配置 "DefaultConnection": "Data Source=localhost;Database=Admin.NET;User ID=root;Password=000000;pooling=true;port=3306;sslmode=none;CharSet=utf8;"
  4. 打开程序包管理器控制台,默认项目Admin.NET.Database.Migrations 执行命令:Add-Migration Init和update-database

【SQLServer】

  1. Admin.NET.EntityFramework.Core 项目安装 Microsoft.EntityFrameworkCore.SqlServer
  2. DefaultDbContext.cs 指定 DbProvider , [AppDbContext("DefaultConnection", DbProvider.SqlServer)]
  3. dbsettings.json 配置 "DefaultConnection": "Server=localhost;Database=Admin.NET;User=sa;Password=000000;MultipleActiveResultSets=True;"
  4. 打开程序包管理器控制台,默认项目Admin.NET.Database.Migrations 执行命令:Add-Migration Init 和 update-database
提示:其他类型数据库依次类推,首先添加EF的Core版包,然后指定数据库类型,修改数据库连接字符串,执行EF迁移命令即可。

【数据库初始化操作】 GIT完成后默认为SqlLite数据库,使用其他数据库可通过基于EF Core的CodeFirst初始化,添加好拓展包,创建好空数据库,设置好数据库信息和后,即可通过此操作可进行数据库初始化操作。

  1. 启动项目设置为 XXXX.Web.Entry
  2. 程序包管理控制台默认项目设置为 XXXX.Database.Migrations
  3. 依次输入并回车执行
    Add-Migration v1.0.0 -Context DefaultDbContext
    update-database v1.0.0 -Context DefaultDbContext
    Add-Migration v1.0.0 -Context MultiTenantDbContext
    update-database v1.0.0 -Context MultiTenantDbContext

至此完成初始数据部署。后期添加/修改自己业务的数据类后通过更新版本号来更新数据库即可。

    Add-Migration v1.0.1 -Context DefaultDbContext
    update-database v1.0.1 -Context DefaultDbContext
    Add-Migration v1.0.1 -Context MultiTenantDbContext
    update-database v1.0.1 -Context MultiTenantDbContext

【EF批量操作】

使用 Zack.EFCore.Batch https://hub.fastgit.org/yangzhongke/Zack.EFCore.Batch 安装对应包即可

  1. MSSQL:Zack.EFCore.Batch.MSSQL
  2. MySql:Zack.EFCore.Batch.MySQL.Pomelo
  3. Npgsql:Zack.EFCore.Batch.Npgsql
  4. Oracle:Zack.EFCore.Batch.Oracle
  5. Sqlite:Zack.EFCore.Batch.Sqlite
提示:记得修改Admin.NET.EntityFramework.Core层里面Startup注册服务类型 opt.UseBatchEF_Sqlite(), 改成相应得库类型。

�� 贡献代码

Admin.NET 遵循 Apache-2.0 开源协议,欢迎大家提交 PRIssue

感谢每一位贡献代码的朋友。感谢 TLog 作者 提供的贡献者实时头像。

Giteye chart

�� 特别鸣谢

  • 1、 依赖流程: mysql-v5.7=>统一用户授权系统(dotnet-v2.2,yarn)=>专家系统后端(dotnet-v2.2)=>专家系统前端(node-v8.16.0,npm,cnpm) 2、 将统一用户授权系统、专家系统后端、专家系统前端git clone下来 3、打开3个命令行窗口: 窗口1:统一用户授权系统(User.Admin) cd到src目录下的 (IdentityServ

  •  通过读取文件的方式: FileStream stream = File.Open(filePath, FileMode.Open, FileAccess.Read); IExcelDataReader excelReader; //1. Reading Excel file if (Path.GetExtension(filePath).ToUpper() == ".XLS") { /

  • 出现问题: 登陆后台跳转http://www.zhzz.org/xxxx.php/index/login?url=%2Fxxx.php之后界面报错404,一般出现在PHP7.3 问题原因: PHP版本最多支持PHP7.1,不支持PHP7.2 PHP7.3 PHP7.4 解决方案: 安装php7.1,如果使用的是宝塔,需要将运行目录改为/public,另外伪静态选thinkphp

  • 微软文档 https://docs.microsoft.com/zh-cn/previous-versions/dotnet/netframework-4.0/ee358758%28v%3dvs.100%29 一.LINQ语法查询 1. 结果不要属性名以数组形式返回 var role = from e in _masterDB.EmployeeRoleAdminAcl joi

 相关资料
  • 本文向大家介绍基于.NET平台常用的框架和开源程序整理,包括了基于.NET平台常用的框架和开源程序整理的使用技巧和注意事项,需要的朋友参考一下 自从学习.NET以来,优雅的编程风格,极度简单的可扩展性,足够强大开发工具,极小的学习曲线,让我对这个平台产生了浓厚的兴趣,在工作和学习中也积累了一些开源的组件,就目前想到的先整理于此,如果再想到,就继续补充这篇日志,日积月累,就能形成一个自己的组件经验库

  • 主要内容:基于 xinetd 服务的启动,基于xientd 服务的自启动本节学习基于 xinetd 服务的管理方法。基于 xinetd 的服务同样有启动管理和自启动管理之分,而且不管是启动管理还是自启动管理,都只有一种方法,相比独立的服务简单一些。 基于 xinetd 服务的启动 基于 xinetd 的服务没有自己独立的启动脚本程序,是需要依赖 xinetd 的启动脚本来启动的。xinetd 本身是独立的服务,所以 xinetd 服务自己的启动方法和独立服务的启动方法

  • 唯一安全的服务器是关闭的。尽管如此,对于服务器访问控制的一个好方法是, 使用经过私钥短语保护的 SSH 密钥的用户帐户, 而不是多个用户使用一个共享账号和一个众所周知的口令。 Puppet 使这种管理变得简单,感谢其内置的 ssh_authorized_key 类型。 将它与上一节讲述的虚拟用户相结合,你可以创建一个包括 user 和 ssh_authorized_key 的 define。 对于

  • jfinal是由jfinal2.2+freemarker+easyui写的一个后台管理系统,参考了jty等一些优秀的开源项目,实现了一个基础的后台管理系统。 在线访问:http://moriiy.wicp.net/jfinal/ 有时可能无法访问(毕竟是部署在自己电脑上的),尽量白天访问,进入系统尽量不要做修改或删除操作。 帐号:admin 密码:123456 测试 test 密码123456

  • 本文向大家介绍.net core使用redis基于StackExchange.Redis,包括了.net core使用redis基于StackExchange.Redis的使用技巧和注意事项,需要的朋友参考一下 .net core使用redis基于StackExchange.Redis教程,具体如下 一.添加引用包 StackExchange.Redis Microsoft.Extensions.

  • htpasswd建立和更新用于基本认证的存储用户名/密码的文本文件。如果htpasswd不能读写此文件,它返回一个出错代码,而不做任何修改。 服务器上的资源可以被限制为仅允许由htpasswd建立的文件中的用户所访问。此程序只能管理存储在文本文件中的用户名和密码,但是它可以加密并显示密码信息,从而可以为其他数据存储类型所利用。要使用DBM数据库,请参见dbmmanage 。 htpasswd使用专