SimpleAdmin手摸手教学之:项目架构设计2.0

yizhihongxing

一、说明

在SimpleAdmin1.0版本中,我将整体项目结构分为三大块,分别为架构核心业务模块应用服务。随着1.0版本的封版,回去再看我之前的项目架构,也暴露了一些问题,比如在1.0版本中,Signalr和Mqtt只能二选一,这显然是不科学的,因为这两种虽然都可以作为消息通知,但是显然可以有更多的应用场景,所以如果两者只能用其一的话,显然整个项目架构就不灵活了。并且随着功能越来越多,太多的代码集合在一个应用中,仅仅以文件夹区分功能模块的话,会不会导致项目越来越臃肿?慢慢的就成了屎山了。这个时候我就想到了很多系统都会采用的插件式开发的模式,在业务模块中,除了基础的功能之外,一些拓展性功能采用插件的方式创建在独立的类库中,这样的话我们想要用哪个功能就引用该功能的项目,如果功能有问题我们也能快速定位到代码的位置,非常方便。于是,我就在SimpleAdmin1.0的基础上,对现有架构进行重新设计,以下是2.0架构设计的一些特色:

  1. 插件式开发:分层明确,减少代码耦合性,增强代码可读性,避免项目成为屎山。
  2. Signalr和Mqtt并存:将Mqtt和Signalr都封装成插件使用,想要使用哪个就引用那个插件,并且支持同时引用。
  3. 支持MemerCache:支持内存缓存,无需依赖redis即可启动项目。

二、项目结构

2.0的项目结构主要分为架构核心系统插件业务模块应用服务,相比于1.0,多了一个插件层。

如图所示:

SimpleAdmin手摸手教学之:项目架构设计2.0

三、分层说明

3.1 架构核心

SimpleAdmin.Core->核心层

核心层,公共组件,常量,枚举,通用方法等其他核心代码,可以被任何项目引用,不依赖其他项目。

│  Core.Development.json  -->  开发环境配置
│  Core.Production.json  -->  生产环境配置
│  Startup.cs  -->  启动类
├─Attributes  -->  特性
├─BaseInput  -->  共用输入参数(分页,ID传参等)
├─Components  -->  公共组件
├─Const  -->  常量
├─Dto  -->  数据类
├─Extension  -->  拓展
├─UnifyResult  -->  统一返回结果
└─Utils  -->  工具类(验证码,图片处理,种子数据处理等)

3.2 系统插件

系统插件是新增的一层,目的是把一些通用的代码抽取出来,封装成类库插件的形式,给不同的项目引用,如果需要哪个功能,直接引用对应的插件即可,非常清晰。哪个功能有问题直接去对应的插件查找,非常方便。这里不做过多的介绍,后面将单开一篇教程详细介绍插件功能。

3.2.1 核心插件

核心插件通常放置一些系统通用插件,如orm,缓存等,这些是系统的基础,基本上所有业务模块都需要用到的插件。

├─SimpleAdmin.Plugin.Aop  -->  Aop插件
├─SimpleAdmin.Plugin.Cache  -->  缓存插件
├─SimpleAdmin.Plugin.CodeFirst  -->  CodeFirst数据库初始化插件
├─SimpleAdmin.Plugin.Core  -->  插件核心,被其他插件引用
├─SimpleAdmin.Plugin.SqlSugar  -->  SqlSugar ORM插件

3.2.2 系统模块插件

系统模块插件主要是对应的我们SimpleAdmin.System层所用到的插件。

├─SimpleAdmin.Plugin.Batch  -->  批量编辑插件
├─SimpleAdmin.Plugin.Gen  -->  代码生成器插件
├─SimpleAdmin.Plugin.ImportExport  -->  批量导入导出插件
├─SimpleAdmin.Plugin.Mqtt  -->  MQTT插件
├─SimpleAdmin.Plugin.Signalr  -->  Signalr插件

3.3 业务模块

SimpleAdmin.System->系统应用层

系统应用层,主要是提供系统应用服务给Api接口层调用,SimpleAdmin的主要功能都由该层实现。

│  Startup.cs  --> 启动类
│  System.Development.json  -->  开发环境配置
│  System.Production.json  -->  生产环境配置
├─EventSubscriber  -->  事件总线
├─Oss  -->  对象存储
├─Services  -->  服务(系统功能接口加实现)
└─UserManager  -->  用户中心(获取当前请求用户信息)

SimpleAdmin.Application->业务应用层

业务应用层,主要是业务代码的编写,可以将自己的业务写在该层,当然也可以自己新建一层写。本系统该层主要是用作数据权限示例。

│  Application.Development.json  --> 开发环境配置
│  Application.Production.json  --> 生产环境配置
│  Startup.cs  --> 启动类
└─Service  --> 服务(业务功能实现)

3.4 应用服务

3.4.1 Web

SimpleAdmin.Web.Entry->启动层

Web 入口层,主要作用就是作为程序入口,没有什么实际业务,没啥好讲的,主要是一些全局的设置,详情见appsettings.json

│-- appsettings.json --> 启动层配置文件
│-- ip2region.db --> 解析ip用的数据库文件
│-- Program.cs --> 启动类

SimpleAdmin.Web.Core->WebApi接口层

Api接口层,存放web应用所需要用到的代码,如组件,控制器,中间件,过滤器等。

│  Startup.cs  --> 启动类
│  Web.Development.json  --> 开发环境配置
│  Web.Production.json  -->  生产环境配置
├─Components  --> 存放Web组件
├─Controllers --> 存放控制器
├─Filter  --> 过滤器
├─Handlers  -->  处理器
└─Logging  -->  操作日志功能
└─Options  -->  配置文件转实体选项类

3.4.2 后台服务

SimpleAdmin.Background->后台服务层

后台服务层,作为定时任务,MQTT或其他服务载体常驻于后台,不依赖于Web,不会因web服务升级而停止。这样做的好处就是不会被iis内存回收,也不会因为web服务升级而停止工作。

│  Background.Development.json  --> 开发环境配置
│  Background.Production.json  --> 生产环境配置
│  MqttWorker.cs  --> mqtt后台任务
│  Program.cs  -->  启动类
├─Dto  -->  数据转换类

四、总结

SimpleAdmin2.0的架构在1.0的基础上进行了很大的调整,回头再看1.0的代码确实有点屎山那味了,还好在1.0完成之后并没有急着开发新的功能而是重新梳理代码逻辑,优化架构,为以后的新功能开发打好基础,这对我自己来说也是一种进步。在日常工作中也一样,如果你回头看几个月之前写的代码发现可以以更好的方式实现时,说明你的代码水平已经进步了。或许在不久的将来,2.0的架构设计也会被推翻重新设计也说不定?,希望能和使用SimpleAdmin开发的coder们一起进步。

原文链接:https://www.cnblogs.com/huguodong/p/17287979.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:SimpleAdmin手摸手教学之:项目架构设计2.0 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • C#中的扩展方法详解

    C#中的扩展方法详解 扩展方法是C#语言中一项非常有用的特性,它允许我们在不直接修改已有类的情况下,为这些类添加新的实例方法。这种机制可以避免因为继承或组合方式造成的类数量爆炸性增长,并且可以使得代码更加清晰易懂。本文将详细讲解C#中的扩展方法,包括如何定义、使用、注意事项等。 定义扩展方法 定义一个扩展方法需要满足以下条件: 它所属的类必须是static类…

    C# 2023年6月1日
    00
  • 使用C#9中records作为强类型ID的实例教程

    使用C#9中records作为强类型ID可以让程序变得更加健壮和安全,让我们来一步步学习如何使用它。 什么是records? records是C#9的新特性,它是值类型,用来表示不可变的数据对象,其简洁的语法使得代码更加易读、易写。 在records类型中,可以定义只读属性、可写属性和自动属性,但是不允许定义私有控制器,因为records类型是不可变的。 下…

    C# 2023年5月31日
    00
  • ASP.NET MVC把数据库中枚举项的数字转换成文字

    以下是“ASP.NET MVC把数据库中枚举项的数字转换成文字”的完整攻略: 什么是枚举 枚举是一种特殊的数据类型,它定义了一组命名的常量。在.NET MVC中,枚举通常用于表示状态、类型等。 ASP.NET MVC把数据库中枚举项的数字转换成文字的过程 以下ASP.NET MVC把数据库中枚举项的数字转换成文字的详细过程: 步骤1:定义枚举 首先,我们需要…

    C# 2023年5月12日
    00
  • C# 使用 OleDbConnection 连接读取Excel的方法

    C# 使用 OleDbConnection 连接读取Excel的方法 要使用 C# 语言连接读取 Excel 文件,可以使用 OleDbConnection 类进行操作。下面将介绍 C# 使用 OleDbConnection 连接读取 Excel 的方法及示例。 步骤一:引用命名空间 使用 OleDbConnection 类需要引用以下命名空间: using…

    C# 2023年6月2日
    00
  • C#中私有构造函数的特点和用途实例解析

    接下来我将详细讲解「C#中私有构造函数的特点和用途实例解析」。 什么是私有构造函数 首先,我们需要了解构造函数是什么。在C#中,构造函数是用来创建对象的特殊方法。它与类同名,并且没有返回值。它可能包含参数,也可能不包含参数。当对象创建时,构造函数会自动执行。在类中,如果没有定义任何构造函数,则编译器会自动定义一个默认构造函数,该构造函数没有参数。 私有构造函…

    C# 2023年6月8日
    00
  • 深入理解C#实现快捷键(系统热键)响应的方法

    深入理解C#实现快捷键(系统热键)响应的方法 简介 快捷键是提高操作效率的一种手段。在Windows系统中,除了软件自带的快捷键外,还可以通过系统热键实现全局快捷键。在C#中实现快捷键,需要使用Win32 API。本文将深入介绍C#实现快捷键响应的方法。 方法 C#实现快捷键响应的方法主要分为以下几步: 注册系统热键 实现热键响应函数 捕捉系统消息 销毁系统…

    C# 2023年6月7日
    00
  • Asp.Net中文本换行

    让我来给您讲解”Asp.Net中文本换行”的完整攻略吧。 1.使用Html的<br>标签 在Asp.Net中,我们可以使用Html的<br>标签来实现文本换行,这个标签可以在Razor视图中或在代码中使用。以下是使用<br>标签的示例: <p> 第一行文本<br> 第二行文本<br> 第…

    C# 2023年6月3日
    00
  • C# 计算标准偏差相当于Excel中的STDEV函数实例

    计算标准偏差(Standard Deviation)是统计学中的一个重要概念,它是一组数据的离散程度的度量标准。在统计分析中,标准偏差用来衡量数据集中数据的分散情况。在C#中,可以使用Math库中的方法进行计算。下面是计算标准偏差相当于Excel中STDEV函数实例的完整攻略。 步骤一:定义数据 首先,我们需要定义一组数据作为计算标准偏差的数据源。假设我们有…

    C# 2023年6月8日
    00
合作推广
合作推广
分享本页
返回顶部