走向.NET架构设计—第四章—业务层分层架构(中篇续篇)

简介:



走向.NET架构设计第四章业务层分层架构(中篇)

  前言:  在上一篇文章中,我们讨论了两种组织业务逻辑的模式:Transaction Script Active Record 。在本篇中开始讲述Domain Model Anemic Model
       注:不管技术的道路多么难走,我们还是得踏踏实实的把技术做下去。也希望朋友们能够一如既往的支持本系列。
 
本篇议题如下:
Transaction Scrip( 前篇)
Active Record 前篇)
Domain Model (中篇)
Anemic Model (后篇)
DDD (后篇)
 
 
  Domain Model
在开发过程中,我们常常用 Domain Model 来对目标的业务领域建模。通过 Domain Model 建模的业务类代表了目标领域中的一些概念。而且,我们会看到通过 Domain Model 建模的一些对象模拟了业务活动中的数据,有的对象还反映了一些业务规则。
 
我们就来看看电子商务系统的开发,在开发中我们建立了一些概念的模型来反映电子商务领域中的一些概念:购物车,订单,订单项等。这些模型有自己的数据,行为。例如一个订单模型,它不仅仅包含一些属性(流水号,创建日期,状态)来包含自己的数据,同时它也包含了一些业务逻辑:下订单的用户时候合法,下订单用户的余额是否充足等。
 
一般来说,我们对领域了解的越深,我们在软件中建立的模式越接近现实中的概念,最后实现的软件就越符合客户的需求。同时在建模的过程中,也要考虑模型的可实现行,可能我们对领域进行了很好的建模,和符合目标领域的一些概念,但是在软件实现起来非常的困难,那么就得权衡一下:找出一个比较好的模式,同时也便于实现。
 
在以前的文章中其实也提到过一些有关 Domain Model 的一些东西,其实 Domain Model Active Record 的一个区别在于: Domain Model 不知道自己的数据时如何持久化的,即 PI Persistence Ignorance . 也就是说,通过 Domain Model 建立的业务类,都是 POCO Plain Old Common Runtime Object )。
 
创建一个新的解决方案,命名为 ASPPatterns.Chap4.DomainModel ,并且添加如下的项目:
 
 
   
下面就来看看每个项目代表的含义:
 
其中:
AgileSharp.Chapter4.DomainModel.Model :业务层,在这个类库项目中包含了系统中所有的业务逻辑和业务对象,以及业务对象之间的关系。这个项目也定义了持久化领域对象的接口,并且是用 Repository  模式来实现的( Repository  这个模式我们后面会谈到)。这个 Model 层没有对其他的类库项目进行引用,完全关注于业务。
AgileSharp.Chapter4.DomainModel.Repository :这个 Repository 的类库项目实现了在 Model  类库中定义的持久化接口。 Repository Model  类库项目进行了引用。
AgileSharp.Chapter4.DomainModel.Infrastructure :提供辅助功能,例如发送邮件,记录日志等。
AgileSharp.Chapter4.DomainModel.Contact :包含数据契约和服务契约。
AgileSharp.Chapter4.DomainModel.Service :服务层,实现契约层提供的服务接口,并且通过 Web Service 接口向外界暴露服务。
AgileSharp.Chapter4.DomainModel.WCFHost WCF 宿主程序。
AgileSharp.Chapter4.DomainModel.WPFUI :主要是负责最后的显示逻辑和一些用户体验的实现。这个类库调用服务层提供的 API ,来提交请求和显示结果。
 
   很多时候可以根据业务模型设计出数据模型(例如,数据表),然后采用相应的策略,并遵循一定的规则,来确保对数据进行高效存取(有关数据模型和领域模型的相关话题,在本书第7 章的“领域模型 VS.  逻辑模型”一节会详细讲述)。此处,领域模型比较简单,对应的数据模型的结构基本和领域模型一样,但是在很多的系统中,领域模型和数据模型是不一样的,例如,一个业务模型的数据要来自于多个数据模型。
 
下面首先建立 Order 领域类,如下所示:
 
public  class Order
{
         public  string OrderNo {  getset; }
         public OrderStatus Status {  getset; }
         public List<OrderItem> Items {  getset; }

     // 计算订单的总价
         public  decimal CaculateTotalPrice()
        {
             decimal result =  0;
             if ( this.Items !=  null &&  this.Items.Count >  0)
            {
                result =  this.Items.Sum(u => u.Products.Sum(p => p.Price));
            }
             return result;
        }
     // 检查订单的状态,判断订单是否已经被处理
         public  bool CheckStatus()
        {
             return  this.Status != OrderStatus.Processed;
        }
    }

     public  enum OrderStatus
    {
        New,
        Processed
    }
}
     正如之前所讲:每个业务类只关注自身的业务,而每个流程又是多个业务类和其他一些辅助类组合完成的,很多的时候都会在领域层中加入服务类,形成很“薄”的服务层(也称为应用层)。下面我们来讨论一下有关服务层的话题(本书的第5 章将对服务层进行深入讨论)。
处理领域逻辑常见的方法是将领域层(也称“业务层”)细分为两层:在领域层中把服务类独立出来,作为服务层
 
    数据访问在这里的实现比较简单,主要是用 Linq To Sql 来实现 IOrderRepository  IProductRepository 接口的,代码如下所示,此处不再赘述:
 
public  interface IOrderRepository
{
         bool Save(Order order);
}

public  interface IProductRepository
{
        Product GetProductByName( string productName);
}
 
     最后我们就是处理显示层。
  在本例子中,显示层就是用传统的 ASP.NET 来实现的,而且用了最简单的实现,如果需要,大家可以采用 MVP 模式,这点在我的另一文章(走向.NET架构设计—第三章—分层设计,初涉架构(中篇) )中详细的讲述了,这里不在赘述,也希望大家见谅。
 
 
  到这里 Domain Model 就基本讲述完了,我们可以看出:当软件中的业务比较的负责的时候,我们用 Domain Model 可能比较的好。因为用 Domain Model 的时候,我们的把所有的精力主要关注在对业务领域的建模,把业务的概念抽象出来,变为软件可以实现的模型。其实抽象出业务模式不是那么容易的事情,往往必须对领域作出比较深入的分析才行。
 
          同时,在业务建模和可实现性之间要有权衡,有时候,我们把业务分析的很透,但是分析出来的概念无法转为实现,产生了“水至清则无鱼”。希望大家多多的琢磨几种组织业务逻辑模式的区别。 
 
  今天就到这里了,还是希望多多见谅,支持!谢谢啊!


















本文转自yanyangtian51CTO博客,原文链接: http://blog.51cto.com/yanyangtian/415734  ,如需转载请自行联系原作者

相关文章
|
2月前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
151 6
|
2月前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
57 1
|
2月前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
43 3
|
3月前
|
消息中间件 运维 数据库
架构设计之解析CQRS架构模式!
架构设计之解析CQRS架构模式!
架构设计之解析CQRS架构模式!
|
2月前
|
数据管理 Nacos 开发者
"Nacos架构深度解析:一篇文章带你掌握业务层四大核心功能,服务注册、配置管理、元数据与健康检查一网打尽!"
【10月更文挑战第23天】Nacos 是一个用于服务注册发现和配置管理的平台,支持动态服务发现、配置管理、元数据管理和健康检查。其业务层包括服务注册与发现、配置管理、元数据管理和健康检查四大核心功能。通过示例代码展示了如何在业务层中使用Nacos,帮助开发者构建高可用、动态扩展的微服务生态系统。
130 0
|
3月前
|
存储 消息中间件 前端开发
.NET常见的几种项目架构模式,你知道几种?
.NET常见的几种项目架构模式,你知道几种?
121 0
|
5月前
|
设计模式 存储 前端开发
揭秘.NET架构设计模式:如何构建坚不可摧的系统?掌握这些,让你的项目无懈可击!
【8月更文挑战第28天】在软件开发中,设计模式是解决常见问题的经典方案,助力构建可维护、可扩展的系统。本文探讨了.NET中三种关键架构设计模式:MVC、依赖注入与仓储模式,并提供了示例代码。MVC通过模型、视图和控制器分离关注点;依赖注入则通过外部管理组件依赖提升复用性和可测性;仓储模式则统一数据访问接口,分离数据逻辑与业务逻辑。掌握这些模式有助于开发者优化系统架构,提升软件质量。
68 5
|
1月前
|
弹性计算 API 持续交付
后端服务架构的微服务化转型
本文旨在探讨后端服务从单体架构向微服务架构转型的过程,分析微服务架构的优势和面临的挑战。文章首先介绍单体架构的局限性,然后详细阐述微服务架构的核心概念及其在现代软件开发中的应用。通过对比两种架构,指出微服务化转型的必要性和实施策略。最后,讨论了微服务架构实施过程中可能遇到的问题及解决方案。
|
2月前
|
Cloud Native Devops 云计算
云计算的未来:云原生架构与微服务的革命####
【10月更文挑战第21天】 随着企业数字化转型的加速,云原生技术正迅速成为IT行业的新宠。本文深入探讨了云原生架构的核心理念、关键技术如容器化和微服务的优势,以及如何通过这些技术实现高效、灵活且可扩展的现代应用开发。我们将揭示云原生如何重塑软件开发流程,提升业务敏捷性,并探索其对企业IT架构的深远影响。 ####
53 3
|
2月前
|
Cloud Native 安全 数据安全/隐私保护
云原生架构下的微服务治理与挑战####
随着云计算技术的飞速发展,云原生架构以其高效、灵活、可扩展的特性成为现代企业IT架构的首选。本文聚焦于云原生环境下的微服务治理问题,探讨其在促进业务敏捷性的同时所面临的挑战及应对策略。通过分析微服务拆分、服务间通信、故障隔离与恢复等关键环节,本文旨在为读者提供一个关于如何在云原生环境中有效实施微服务治理的全面视角,助力企业在数字化转型的道路上稳健前行。 ####