一.基础知识准备:

  1.层的原则:

  (1)每一层以接口方式供上层调用。
  (2)上层只能调用下层。
  (3)依赖分为松散交互和严格交互两种。

  2.业务逻辑分类:

  (1)应用逻辑。
  (2)领域逻辑。

  3.采用的层:

  (1)表示层(用户接口层):领域无关。
  (2)服务层(应用层):应用逻辑。
  (3)业务逻辑层(领域层):领域逻辑。
  (4)共享层:提供通用代码。
  (5)实现层:提供接口实现。

  4.约定:

  (1)领域层默认采用领域模型
  (2)数据访问层默认需要引用领域模型

  二.分层架构

  分层架构的三个基本层次为:表示层、业务逻辑层和数据访问层。如果按照业务逻辑的分类将业务逻辑层分解为服务层和领域层,则三层扩展为四个层次:表示层、服务层、领域层和数据访问层。数据访问层一般必须了解领域模型,这将在层之间产生双向依赖,通常我们有如下两种解决方案:

  1.将领域模型放置在共享层:

  评价:PetShop采用此种模型,但缺点众多:业务逻辑层名不副实,领域模型实为数据模型,保持了层间依赖,引入了更多依赖,明显的数据驱动思想,没有以领域为核心。

  2.将数据访问接口定义在业务逻辑层:

  评价:NopCommerce采用此种模型,即使采用分离出了服务层和采用了资源库命名方式,但NopCommerce不是DDD分层架构,只是采用了领域模型和接口分离原则的普通三层架构。缺点:除了数据房产,没有将其他具体的技术依赖从业务逻辑层中分离。

  三.DDD分层:

  DDD分层明确的将业务逻辑层分成了应用层(服务层)和领域层两部分。同时将数据访问和其他接口的具体技术实现部分统一到了基础设施层。

  1.原始的DDD分层:

  评价:优点是将具体技术实现从领域分离,基础设施层复用价值增加。缺点是没有使用共享和实现的概念细分基础设施层,导致在基础设施层中实现仓储会产生反向依赖,虽然在单项目解决方案中没有影响(仅命名空间层次的形式上的依赖),但在.NET多项目解决方案中,只能通过接口分离方式将仓储实现独立成类似数据访问层的方式。

  2.改善的DDD分层:

  评价:基础设施层同时具有共享层和实现层的特征。优点是终于做到了形式上领域为核心且同时解决了在基础设施层中实现仓储不能引用领域模型的尴尬,缺点是同样没有区分共享和实现的概念。

  3.最新的DDD分层:

  评价:优点是这是真正的以领域为核心,再也不用为基础设施层无法引用领域层而再服务层中再次适配了。使用依赖倒置原则彻底各层对具体技术的依赖倒置。缺点,依赖倒置应用过了头,同样是在单项目解决方案中没有问题,但在.NET多项目解决方案中会导致命名空间形式上的双向依赖。基础设施层作为实现层基本上没有了复用的价值。更好的方式是调换图中用户接口层和基础设施层的位置。

  可以根据需要考虑在上图添加适当的共享层。

  四.架构的趋势:

  (1)以业务逻辑为核心,更加重视业务逻辑。
  (2)将业务逻辑层的具体依赖划分到一个层次统一管理。
  (3)更加重视降低解决方案内的依赖性而不是解决方案间的代码复用。
  (4)共享层和实现层的分离将会越来越多的体现。例如洋葱型架构。

  参考

  1.Patterns of Enterprise Application Architecture 【企业应用架构模式】
  2.Domain-Driven Design 【领域驱动设计:软件核心复杂性应对之道】
  3.Applying Domain-Driven Design and Patterns【领域驱动设计与模式实战】
  4.Implementing Domain-Driven Design 【实现领域驱动设计】
  5.Microsoft Application Architecture Guide 【微软应用架构指南(第2版)】
  6.Professional Enterprise .NET 【精通.NET企业项目开发:最新的模式、工具与方法】
  7.Professional ASP.NET Design Patterns 【ASP.NET设计模式】

.NET逻辑分层架构总结的更多相关文章

  1. [ASP.NET].NET逻辑分层架构总结

    一.基础知识准备: 1.层的原则: (1)每一层以接口方式供上层调用. (2)上层只能调用下层. (3)依赖分为松散交互和严格交互两种. 2.业务逻辑分类: (1)应用逻辑. (2)领域逻辑. 3.采 ...

  2. DDD分层架构的进化

    .NET逻辑分层架构演示:DDD分层架构的进化 概述:   架构是高层的设计,如果设计和理解有误,必将在实现时带来各种问题.架构又是最稳定的,不会因为各种具体技术的依赖,如各种UI框架.ORM框架.I ...

  3. ABP(现代ASP.NET样板开发框架)系列之3、ABP分层架构

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之3.ABP分层架构 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)” ...

  4. Apworks框架实战(四):使用Visual Studio开发面向经典分层架构的应用程序:从EasyMemo案例开始

    时隔一年,继续我们的Apworks框架之旅.在接下来的文章中,我将逐渐向大家介绍如何在Visual Studio中结合Apworks框架,使用ASP.NET Web API和MVC来开发面向经典分层架 ...

  5. 应用程序框架实战十八:DDD分层架构之聚合

    前面已经介绍了DDD分层架构的实体和值对象,本文将介绍聚合以及与其高度相关的并发主题. 我在之前已经说过,初学者第一步需要将业务逻辑尽量放到实体或值对象中,给实体“充血”,这样可以让业务逻辑高度内聚, ...

  6. 应用程序框架实战十五:DDD分层架构之领域实体(验证篇)

    在应用程序框架实战十四:DDD分层架构之领域实体(基础篇)一文中,我介绍了领域实体的基础,包括标识.相等性比较.输出实体状态等.本文将介绍领域实体的一个核心内容——验证,它是应用程序健壮性的基石.为了 ...

  7. 应用程序框架实战十四:DDD分层架构之领域实体(基础篇)

    上一篇,我介绍了自己在DDD分层架构方面的一些感想,本文开始介绍领域层的实体,代码主要参考自<领域驱动设计C#2008实现>,另外参考了网上找到的一些示例代码. 什么是实体 由标识来区分的 ...

  8. 应用程序框架实战十三:DDD分层架构之我见

    前面介绍了应用程序框架的一个重要组成部分——公共操作类,并提供了一个数据类型转换公共操作类作为示例进行演示.下面准备介绍应用程序框架的另一个重要组成部分,即体系架构支持.你不一定要使用DDD这样的架构 ...

  9. 分享一个UI与业务逻辑分层的框架(一)

    序言 .NET(C#)的WinForm如何简单易行地进行UI与业务逻辑分层?本系列文章介绍一个WinForm分层框架,该框架针对WinForm中的TextBox,CheckBox,RadioButto ...

随机推荐

  1. Linq Like

    Like的操作,有点像in,但是,方向变了.什么意思呢.就是你给定一个字符串,去寻找数据中某个字段包含这个字符串.就是给定的字符串是某字段的子集.Sql Script是这么写的. Selec * fr ...

  2. ecshop /goods.php SQL Injection Vul

    catalogue . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述2. 漏洞触发条件 0x1: poc http://localhost ...

  3. 【转载】Linux 与 BSD 有什么不同?

    原创:Linux中国 https://linux.cn/article-3186-1.html 原创:LCTT https://linux.cn/article-3186-1.html 本文地址:ht ...

  4. POJ1741:tree

    传送门 时隔一个月再次写点分治,比上一次要深入理解很多了.(虽然代码还是写不熟 模板题,不多说 //POJ 1741 //by Cydiater //2016.9.22 #include <cs ...

  5. Docker入门教程(三)Dockerfile

    Docker入门教程(三)Dockerfile [编者的话]DockerOne组织翻译了Flux7的Docker入门教程,本文是系列入门教程的第三篇,介绍了Dockerfile的语法,DockerOn ...

  6. python bottle框架

    python bottle框架 简介: Bottle是一个快速.简洁.轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Python的标准库外,其不依赖任何其他模块. Bottl ...

  7. 《Java疯狂讲义》(第3版)学习笔记 1 - 如何学习Java

    1.Java是一种面向对象语言,不要简单当做脚本使用.从基础学起,不要从Spring.J2EE.Hibernate和EJB开始学. 2.不要浮躁,应该扎扎实实先学好Java语言,然后按Java本身的学 ...

  8. MVC过滤器之 OnActionExcuted

    Controller里 [SendMessage] public Action SendSmsMessage() { var resultExtendInfo=new ResultExtendInfo ...

  9. C#------DateTime自定义格式

    var text = Convert.ToString(DateTime.Now.ToString("yyyy/MM/dd"));

  10. Oracle数据库的备份方法

    1.引言 Oracle数据库的备份方法很多,无论使用那种备份方法,备份的目的都是为了在出现故障后能够以尽可能小的时间和代价恢复系统.比如使用export实用程序导出数据库对象.使用Oracle备份数据 ...