浅析.NET逻辑分层架构

 更新时间:2015年11月04日 09:03:32   投稿:lijiao  
这篇文章主要介绍了.NET逻辑分层架构,分层架构的三个基本层次分别为:表示层、业务逻辑层和数据访问层,感兴趣的小伙伴们可以参考一下

一.基础知识准备:

  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)共享层和实现层的分离将会越来越多的体现。例如洋葱型架构。

以上就是关于.NET逻辑架构的简单介绍,希望对大家的学习有所帮助。

相关文章

  • WPF的数据绑定详细介绍

    WPF的数据绑定详细介绍

    数据绑定:是应用程序 UI 与业务逻辑之间建立连接的过程。 如果绑定正确设置并且数据提供正确通知,则当数据的值发生更改时,绑定到数据的视觉元素会自动反映更改。 数据绑定可能还意味着如果视觉元素中数据的外部表现形式发生更改,则基础数据可以自动更新以反映更改。
    2013-03-03
  • ASP.NET MVC3网站创建与发布(1)

    ASP.NET MVC3网站创建与发布(1)

    这篇文章主要介绍了ASP.NET MVC3网站创建与发布,根据文章内容大家可以实现发布网站,感兴趣的小伙伴们可以参考一下
    2015-08-08
  • ASP.NET中ListView(列表视图)的使用前台绑定附源码

    ASP.NET中ListView(列表视图)的使用前台绑定附源码

    ListView(列表视图)想必大家都知道吧,接下来本文将介绍下ListView的使用前台绑定,感兴趣的你可不要错过本文了哈
    2013-03-03
  • ASP.NET 文件断点续传实现代码

    ASP.NET 文件断点续传实现代码

    在文件下载的时候,使用断点续传可以将上次未下载完成的文件继续下载,该功能在开发文件下载的时候非常重要。这里我将介绍一种比较简单的断点续传功能的实现方法,仅供初学者参考使用
    2012-06-06
  • 19个必须知道的Visual Studio快捷键

    19个必须知道的Visual Studio快捷键

    这篇文章主要为大家详细介绍了19个必须知道的Visual Studio快捷键,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • ASP.NET MVC实现城市或车型三级联动

    ASP.NET MVC实现城市或车型三级联动

    这篇文章介绍了ASP.NET MVC实现城市或车型三级联动的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-09-09
  • ASP.NET中实现jQuery Validation-Engine的Ajax验证

    ASP.NET中实现jQuery Validation-Engine的Ajax验证

    在jQuery的表变验证插件中Validation-Engine是一款高质量的产品,提示效果非常精美,而且里面包含了AJAX验证功能
    2012-06-06
  • 嵌套repeater示例分享

    嵌套repeater示例分享

    这篇文章主要介绍了嵌套repeater示例,代码简单,下面直接上代码,需要的朋友可以参考下
    2014-03-03
  • asp.net Checbox在GridView中的应用实例分析

    asp.net Checbox在GridView中的应用实例分析

    这篇文章主要介绍了asp.net Checbox在GridView中的应用,结合实例形式分析了GridView中添加与使用Checbox的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • MVC使用Log4Net进行错误日志记录学习笔记4

    MVC使用Log4Net进行错误日志记录学习笔记4

    这篇文章主要为大家详细介绍了MVC使用Log4Net进行错误日志记录,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09

最新评论