ABP入门教程2 - 体系架构
介绍
应用程序代码库的分层是一种广泛接受的技术,可帮助降低复杂性并提高代码可重用性。为了实现分层体系结构,ASP.NET Boilerplate遵循域驱动设计的原理。
DDD分层体系架构
领域驱动设计(DDD:Domain-Driven Design)有四个基本层:
- 展示层:为用户提供界面。使用应用程序层来实现用户交互。
- 应用层:在表示层和域层之间进行中介。编排业务对象以执行特定的应用程序任务。
- 领域层:包括业务对象及其规则。这是应用程序的核心。
- 基础设施层:提供通用技术功能,这些功能主要使用第三方库来支持更高的层。
ABP分层体系架构
除了DDD外,现代架构应用程序中还包含其他逻辑和物理层。建议并为ABP应用程序实现以下模型。ABP不仅通过提供基类和服务使实现此模型更加容易,而且还提供了直接从该模型开始的启动模板。
客户应用
这些是远程客户端,它们通过HTTP API(API控制器,OData控制器,甚至是GraphQL端点)将应用程序用作服务。远程客户端可以是SPA(单页面应用程序),移动应用程序或第三方用户。本地化和 导航可以在此应用程序内完成。
展示层
ASP.NET Core MVC(模型-视图-控制器)可以视为展示层。它可以是物理层(通过HTTP API使用应用程序)或逻辑层(直接注入和使用应用程序服务)。无论哪种情况,它都可以包括 本地化,导航,对象映射, 缓存,配置管理,审计日志等。它还处理 授权,会话, 功能(用于 多租户应用程序)和异常处理。
分布式服务层
该层用于通过REST,OData,GraphQL等远程API来提供应用程序/域功能...它们不包含业务逻辑,而仅将HTTP请求转换为域交互,或者可以使用应用程序服务来委托操作。该层通常包括授权,缓存, 审核日志记录,对象映射,异常处理,会话等。
应用层
应用层主要包括应用服务的使用领域层和领域对象(领域服务, 实体 ...)来执行请求的应用程序的功能。它使用数据传输对象从表示层或分布式服务层获取数据并将数据返回到表示层或分布式服务层。它还可以处理 授权,缓存,审核日志记录,对象映射,会话等。
领域层
这是实现我们的领域逻辑的主要层。它包括 实体,值对象和领域服务以执行业务/领域逻辑。它还可以包括规范和触发领域事件。它定义了存储库接口以从数据源(通常是DBMS)读取和保留实体。
基础设施层
基础设施层使其他层起作用:它实现存储库接口(例如,使用Entity Framework Core)以实际使用实际数据库。它还可能包括与供应商的集成,以发送电子邮件等。这不是所有层下的严格层,但实际上通过实现抽象层来支持其他层。