DDD实际项目概念扫盲


聚合,实体,对象

电商里面比较典型的几个聚合根,比如:库存、商品、订单等。

以订单为例,订单在聚合里是聚合根,与订单关联的有订单明细和收货地址: 订单明细包括商品ID,商品名称,价格以及数量等信息,由于订单明细是多个,它是一个集合,它被设计为实体, 被订单引用而订单只有一个收货地址,这个收货地址的值来源于你个人中心维护的收货地址,收货地址只能被整体替换,所以它被设计为值对象

保险的投保业务场景

image.png

领域服务

如果一个业务动作或行为跨多个实体,就需要设计领域服务。领域服务通过对多个实体和实体方法进行组合,完成核心业务逻辑。可以认为领域服务是位于实体方法之上和应用服务之下的一层业务逻辑。

按照严格分层架构层的依赖关系,如果实体的方法需要暴露给应用层,它需要封装成领域服务后才可以被应用服务调用。所以如果有的实体方法需要被前端应用调用,会将它封装成领域服务,然后再封装为应用服务。

个人客户聚合根这个实体创建个人客户信息的方法,被封装为创建个人客户信息领域服务。然后再被封装为创建个人客户信息应用服务,向前端应用暴露。

领域服务类放在领域层的 Service 目录结构下。 image.png

下面例子: 应用层提供用户注册服务,但是同时也做了拦截业务逻辑 领域服务是实现用户领域的用户注册服务实现

应用服务

image.png

image.png

领域服务 image.png

评论

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×