热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

领域驱动设计的思考

零散记录,随想随记,在适当的时候再做整合:问题一:对于数据或输入参数的校验应该放到应用层还是领域层?在编写程序时,少不了对输入参数的校验。第一可以减少异常场景,另外也可以节省不必

零散记录,随想随记,在适当的时候再做整合:

问题一:对于数据或输入参数的校验应该放到应用层还是领域层?

在编写程序时,少不了对输入参数的校验。

第一可以减少异常场景,另外也可以节省不必要的执行逻辑,从这个角度讲参数的校验应该尽量靠前,如果参数是异常的话,应该尽早返回给调用方,所以放在应用层的最前端比较合适。

但如果把参数合法性理解成为领域对象的行为,也就是说领域对象是最了解输入参数校验规则的,那么就应该把参数校验逻辑放在领域层。并且,对于调用领域对象的调用方来说,这样是安全可靠的,同时也减少了重复校验的可能性。

结论:不是原则性问题,可以通过定于规范来统一行为,但是一定要有地方定义参数的校验逻辑,无论是在接口文档,还是在领域对象的注释中,并且保证这是唯一定义参数校验逻辑的地方。

问题二:对于事务的控制应该放在哪里?

比较重要,核心的问题。事务的定义:是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。

有几条原则:1. 聚合根首先是原子的,即聚合根内部的操作是原子的;

结论:目前看,事务应该放在应用层来做,由应用层来统一规划事务的范围,毕竟事务的范围是由业务最终决定的。

问题三:领域边界如何界定?

之前一直在纠结一个问题:两个系统交互时,可能会用到同样的对象,例如A系统调用B系统获取User信息,A和B系统都需要定义User的数据结构,那么这个User的数据结构是分别由A和B分别维护,还是在一个Common包中维护?

如果由A和B分别维护,则当User发生变化时,A和B要协调同步修改,这里可能存在没有同步的问题;如果在Common包中维护,而A和B对User的定义有可能不完全一样,所以还需要在A和B中分别再创建UserA和UserB,以区分两者的不同,产生了冗余。

结论:需要结合具体场景来使用。如果把User单纯定义为传输结构的定义而不具备领域含义(即将其定义为应用层概念),那么在Common包中定义比较合适。但如果为了精简结构,User不仅作为传输结构,同时也包含领域意义(那么A和B对User的定义需要在各自的领域范围内赋能,其结构有相似但含义完全不同,比如A中是User,B中可能是Customer),那么就一定要由A和B分别定义了。





推荐阅读
  • 本文探讨了Hive中内部表和外部表的区别及其在HDFS上的路径映射,详细解释了两者的创建、加载及删除操作,并提供了查看表详细信息的方法。通过对比这两种表类型,帮助读者理解如何更好地管理和保护数据。 ... [详细]
  • 本文总结了汇编语言中第五至第八章的关键知识点,涵盖间接寻址、指令格式、安全编程空间、逻辑运算指令及数据重复定义等内容。通过详细解析这些内容,帮助读者更好地理解和应用汇编语言的高级特性。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 新冠肺炎疫情期间,各大银行积极利用手机银行平台,满足客户在金融与生活多方面的需求。线上服务不仅激活了防疫相关的民生场景,还推动了银行通过互联网思维进行获客、引流与经营。本文探讨了银行在找房、买菜、打卡、教育等领域的创新举措。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文探讨了如何在发布 XenApp 应用时,通过命令行参数实现启动时的参数传递。特别介绍了静态和动态参数传递的方法,并详细解释了 ICA 文件中两种参数传递方式的区别及安全检查机制。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 尽管某些细分市场如WAN优化表现不佳,但全球运营商路由器和交换机市场持续增长。根据最新研究,该市场预计在2023年达到202亿美元的规模。 ... [详细]
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 题库来源:安全生产模拟考试一点通公众号小程序G3锅炉水处理报名考试是安全生产模拟考试一点通生成的,G3锅炉水处理证模拟考试题库是根据G3锅炉水处理最新 ... [详细]
  • 为了深入了解辽源市市民对智能城市建设的感受和建议,国家统计局辽源调查队近期开展了一项针对200位市民的问卷调查。结果显示,大部分市民对智能城市的认知度较高,并对其带来的便利表示肯定。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
author-avatar
LoveCherryz
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有