依赖注入:使用多项目解决方案时如何注入

Jam*_*mes 5 dependency-injection ninject

希望这个问题不是太愚蠢,我试图掌握更高级的编程原则,因此试图习惯使用Ninject进行依赖注入.

所以,我的模型被分成几个不同的.dll项目.一个项目定义了模型规范(Interfaces),其他一些项目实现了这些接口.所有模型项目都需要使用某种数据库系统,因此它们都需要访问另一个实现我所有数据库逻辑的.dll.但重要的是,所有这些都可以访问我的数据库对象的同一个实例,因此,如果仅为每个模型创建一个实例是不够的.

不过,我不太确定如何使用依赖注入来实现这一点.我的第一个想法是创建一个单独的DI项目并将所有接口绑定到它们各自的实现,因此DI项目需要引用所有其他项目(模型接口和实现,数据库系统等).然后,模型将需要访问DI项目,因为例如,他们需要从DI系统(Ninject)请求数据库系统.当然这会创建一个循环引用(将DI项目绑定到DI项目的模型和模型),所以这是不可能的.

长话短说,我需要一个编程模式,让我的模型接口绑定到他们的实现,但也允许模型的实现要求从Ninject,如其他依赖

IModel1 -> Model1
IModel2 -> Model2 (different project)
IDatabase -> Database (different project)
Model1 -> request IDatabase -> get Database instance
Model2 -> request IDatabase -> get the same Database instance
Run Code Online (Sandbox Code Playgroud)

很高兴得到一些建议,目前我被困住了,并且没有想法;)谢谢!

Ste*_*ven 8

模型需要访问DI项目,例如,他们需要从DI系统(Ninject)请求数据库系统

当您使用依赖注入时,模型不需要访问DI框架,因为它是注入依赖项的DI框架.模型对象不应该询问DI容器.当您的对象向容器询问依赖关系时,它不会被称为依赖注入,而是服务定位器.服务定位器被认为是反模式.

我的第一个想法是创建一个单独的DI项目

当您拥有单个应用程序(即Web应用程序)时,通常要做的是在最终应用程序中完全配置DI容器,尽可能接近应用程序的入口点.这称为组合根.

所有模型项目都需要使用某种数据库系统,因此它们都需要访问另一个实现我所有数据库逻辑的.dll

尝试制作POCO(普通旧CLR对象)模型/实体对象,或至少确保这些对象不需要引用任何其他项目,这使您的架构(和测试)更容易.


Joe*_*zer 1

客户端应用程序将使用 Ninject 注入实际的数据库和模型实现。

因此,客户端应用程序需要引用数据库、idatabase、model 和 imodel 项目。

idatabase 和数据库项目需要引用模型项目,因为这些方法将返回模型对象或模型对象的集合。看一下存储库模式

您的模型不需要引用您的任何项目。