在Infrastructure层中对所有域层(模块,模型,实体,域服务等)的所有接口进行分组是否有意义?如果没有,创建一个将所有这些组合成共享库的"共享"项目/组件是否有意义?毕竟,"Infrastructure Layer"的定义包括"Domain,Application和UI层的共享库".
我正在考虑围绕DDD层设计我的代码库:UI,应用程序,域,基础架构.这将恭敬地创建4个项目.我的观点是,您从域层引用了基础架构层.但是,如果您在Domain Layer项目中定义接口,比如说IPost,那么当您在定义IPostRepository.Save(IPost post)方法时必须从Infrastructure项目引用Domain Layer项目时,您将有一个循环参考.因此,"定义共享库中的所有接口"的想法.
也许存储库不应该期望一个对象要保存(IPostRepository.Save(IPost post);而是期望对象的params(可能是Save()中的一长串params).给定,这可能是一个理想的情况,显示一个对象变得过于复杂,并且应该为它寻找额外的值对象.
思考?
埃里克,我离开了一对夫妇,所以原谅我这么晚回答.关于存储库的位置,我个人总是将存储库放在专用的基础结构层(例如MyApp.Data.Oracle)中,但是在域层中声明存储库必须符合的接口.
在我的项目中,应用层必须访问域和基础架构层,因为它负责配置域和基础架构层.
应用程序层负责将适当的基础结构注入域中.域名不知道它与哪个基础设施通信,它只知道如何调用它.当然,我使用像Structuremap这样的IOC容器将依赖项注入域中.我再次声明这不是DDD建议构建项目的方式,而是我构建应用程序的方式.干杯.