我正在尝试根据洋葱架构方法重构系统。
我的外层包含以下部分
WCF网络服务(我们提供)
数据库访问的基础设施类
用于访问外部Web服务的基础结构类
测试
我想仔细检查外层的不同段是否允许彼此依赖。例如,WCF类可以直接依赖于基础架构程序集中的任何代码吗?
据我所知,这是不允许的。例如,WCF代码应仅依赖于内层的代码(例如接口)。你能确认一下吗?
PS
我有点困惑,因为一方面有些文章证实了这一点:
http://blog.ploeh.dk/2013/12/03/layers-onions-ports-adapters-its-all-the-same/
你可能已经注意到我把橙色,黄色和黄色分组了 蓝色框分成不同的簇。这是因为我还是想 应用UI组件不得依赖于数据访问的旧规则 组件,反之亦然。因此,我介绍之间的舱壁 这些团体
但另一方面,测试(例如基础架构组件中的代码)与基础架构组件位于同一层,并且直接依赖于它们。
答案 0 :(得分:1)
在物理组件方面谈论,基础设施组件(包含解决[通常]利用特定框架的问题的代码的组件)不应该直接相互引用。相反,您应该(至少根据我的经验)从这些程序集中提取接口并将它们放入其他基础结构程序集可以引用的单独程序集中。以您的(近似)情况为例,您可以执行以下操作:
注意事项:
Global.asax
中。如果您需要更多信息,请与我们联系。