ABP开发手记2 - 体系架构

点这里进入ABP开发手记目录

ABP分层体系架构

介绍

应用程序代码库的分层是一种广泛接受的技术,可帮助降低复杂性并提高代码可重用性。为了实现分层体系结构,ASP.NET Boilerplate遵循域驱动设计的原理

域驱动设计层

域驱动设计(DDD)有四个基本层:

  • 展示层:为用户提供界面。使用应用程序层来实现用户交互。
  • 应用层:在表示层和域层之间进行中介。编排业务对象以执行特定的应用程序任务。
  • 领域层:包括业务对象及其规则。这是应用程序的核心。
  • 基础设施层:提供通用技术功能,这些功能主要使用第三方库来支持更高的层。

ASP.NET样板应用程序体系结构模型

除了DDD外,现代架构应用程序中还包含其他逻辑和物理层。建议并为ASP.NET Boilerplate应用程序实现以下模型。ASP.NET Boilerplate不仅通过提供基类和服务使实现此模型更加容易,而且还提供了直接从该模型开始的启动模板

ASP.NET Boilerplate NLayer体系结构

客户应用
这些是远程客户端,它们通过HTTP API(API控制器,OData控制器,甚至是GraphQL端点)将应用程序用作服务。远程客户端可以是SPA(单页面应用程序),移动应用程序或第三方用户。本地化和 导航可以在此应用程序内完成。

展示层
ASP.NET Core MVC(模型-视图-控制器)可以视为表示层。它可以是物理层(通过HTTP API使用应用程序)或逻辑层(直接注入和使用应用程序服务)。无论哪种情况,它都可以包括 本地化,导航,对象映射, 缓存,配置管理,审计日志等。它还处理 授权,会话, 功能(用于 多租户应用程序)和异常处理。

分布式服务层
该层用于通过REST,OData,GraphQL等远程API来提供应用程序/域功能...它们不包含业务逻辑,而仅将HTTP请求转换为域交互,或者可以使用应用程序服务来委托操作。该层通常包括授权,缓存, 审核日志记录,对象映射,异常处理,会话等。

应用层
应用层主要包括应用服务的使用领域层和领域对象(领域服务, 实体 ...)来执行请求的应用程序的功能。它使用数据传输对象从表示层或分布式服务层获取数据并将数据返回到表示层或分布式服务层。它还可以处理 授权,缓存,审核日志记录,对象映射,会话等。

领域层
这是实现我们的领域逻辑的主要层。它包括 实体,值对象和领域服务以执行业务/领域逻辑。它还可以包括规范和触发领域事件。它定义了存储库接口以从数据源(通常是DBMS)读取和保留实体。

基础设施层
基础设施层使其他层起作用:它实现存储库接口(例如,使用Entity Framework Core)以实际使用实际数据库。它还可能包括与供应商的集成,以发送电子邮件等。这不是所有层下的严格层,但实际上通过实现抽象层来支持其他层。

猜你喜欢

转载自www.cnblogs.com/IT-Evan/p/ABP2.html