分支说明
master - .NET 5 / netcore31 - .NET Core 3.1
演示地址: https://demo.meiam.top/
运行环境 : CENTOS7 / .NET 5 / MYSQL - 后台用户 9999 密码 123456
如果你喜欢这个项目或者它帮助你, 请给 Star~(辛苦咯)
- 采用 服务 + 接口 的形式封装框架 (移除了仓库层)
- 采用 REDIS 存储会话(用户信息 / 用户权限)- 更好的支持分布式应用、用户踢出、登录登出等功能
- 采用 Autofac 依赖注入 IoC 容器, 实现批量自动注入所有服务
- 采用 SqlSugar ORM 组件, DBFirst 开发模式, 封装 BaseService 数据库基础操作类
- 采用 CSRedis 封装缓存层, 可结合 SqlSugar WithCache + RemoveDataCache 自动管理缓存
- 采用 Swagger 自动生成 WebAPI 说明文档
- 采用 Mapster 高性能对象映射, 代码书写更简洁
- 采用 NLog 日志组件, 集成 Microsoft.Extensions.Logging (ILogger 注入)操作日志
- 采用 NLog.Web.AspNetCore 日志扩展组件, 增加 layout 更多属性
- 采用 Quartz.Net 封装任务调度中心功能
- 封装全局 会话 管理器 (用户 Token 会话管理)
- 封装全局 权限 拦截器 (用户 Permission 权限管理)
- 封装全局 异常 拦截器 (自动记录系统异常日志)
- 封装全局 请求 拦截器 (自动记录接口请求日志)
- 支持 用户功能权限、 用户数据权限分配
- 支持 CORS 跨域配置
- 支持代码生成器,自动生成 Model 、Service 、 IService 层
- 支持跨方法事务方案,把事务提取到逻辑层进行统一事务提交,让你的代码更加漂亮
- 支持多种数据库 Sqlite/SqlServer/MySql/PostgreSQL/Oracle 自由切换
- 支持数据库 读写分离 和 多库 操作
- 计划 RabbitMQ 消息列队集成
- 计划 ImCore 及时通讯组件集成
# | 模块功能 | 项目文件 | 说明 |
---|---|---|---|
1 | 基础库 | Meiam.System.Common | 存放常用类库 、加密解密单元等 |
2 | 核心库 | Meiam.System.Core | 数据库、缓存相关类 |
3 | 扩展库 | Meiam.System.Extensions | 外部接口引用集成 |
4 | 服务层 | Meiam.System.Interfaces | Service 、 IServer, 基础服务类 |
5 | 模型层 | Meiam.System.Model | Entity、Dto、ViewModel |
6 | 业务层 | Meiam.System.Hostd | WebAPI |
7 | 工具库 | Meiam.System.Tools | 代码生成器 |
8 | 定时任务 | Meiam.System.Tasks | 任务调度中心 |
还在陆续整理中
还在陆续整理中
项目默认使用的是 SQLServer, 请导入备份文件 [Meiam.System-SQLServer.sql] 。
如果你使用 MySQL 数据, 请选择对应的备份文件 [Meiam.System-MySQL.sql] 复制 [NLog-MySQL.config] Meiam.System.Hostd 目录重命名为 NLog.config
// 数据库连接
"DbConnection": {
"ConnectionString": "Server=192.168.0.3;Database=MeiamSystem;UID=meiamsystem;Password=HApVpL8XhFFGz3Oy",
"DbType": 1 //<= 配置你要选用的数据库 MySql = 0, SqlServer = 1, Sqlite = 2, Oracle = 3, PostgreSQL = 4
},
// REDIS 配置 , 默认使用了 3 个 DB
"RedisServer": {
"Cache": "192.168.0.3:6379,password=redis,preheat=5,idleTimeout=600,defaultDatabase=13,prefix=Cache",
"Sequence": "192.168.0.3:6379,password=redis,preheat=5,idleTimeout=600,defaultDatabase=14,prefix=Sequence:",
"Session": "192.168.0.3:6379,password=redis,preheat=5,idleTimeout=600,defaultDatabase=15,prefix=Session:"
},
// 跨域配置
"Startup": {
"ApiName": "Meiam.System",
"ApiUrls": "http://*:19999",
"AllowOrigins": "http://127.0.0.1:18888|http://localhost:18888"
},
// TOKEN 过期时间配置
"AppSettings": {
"Demo": true, //<= 关闭演示模式
"WebSessionExpire": 24,
"MiniProgramSessionExpire": 720
},
// 头像上传目录
"AvatarUpload": {
"AvatarDirectory": "D://wwwroot/avatars",
"AvatarUrl": "/"
}
dotnet Meiam.System.Hostd.dll
贡献的最简单的方法之一就是是参与讨论和讨论问题(issue)。你也可以通过提交的 Pull Request 代码变更作出贡献。
anjoy8/Blog.Core 借鉴了作者定时任务的写法