如何在mvc站点的类项目部分初始化Ninject

我在一个小项目中使用了Ninject,但现在我正在将一个更大的Web应用程序转换为mvc并需要使用Ninject的帮助.在新的解决方案中,我有mvc站点,并将一些功能拆分为单独的类项目,例如,我的ReportGenerator.

我想在ReportGenerator中使用Ninject来解决它的依赖关系,但我不希望MVC项目知道ReportGenerator的内部工作原理.那么我在哪里创建绑定/内核?

我已经查看了其他问题,例如:Referencing Ninject in class library in ASP.NET MVC 3 application但是答案似乎表明绑定是在我不想要的MVC项目中设置的.

有人能指出我在一个类中配置/运行Ninject的示例代码,该类由一个也将使用Ninject的MVC项目引用吗?

最佳答案 您应该注册并解决
Composition Root中的所有组件.这与Ninject无关,并且此建议适用于所有DI容器.

组合根是应用程序的启动路径,您可以将所有内容连接在一起.您通常会将此组合根放在启动项目中;在你的情况下你的MVC项目.

您通常不应该担心这一点,因为您的MVC程序集本身依赖于另一个程序集的详细信息,并不意味着您的UI逻辑(例如您的控制器)依赖于这些细节.如您所知,控制器应该只依赖于抽象.不要将您的逻辑体系结构(层的分离)与物理体系结构混淆(在部署期间如何在磁盘上分离代码).尽管组合根可以位于同一个程序集中,但它与MVC结束项目在逻辑上是分开的.

组合根通常是运行时首先运行的应用程序的代码路径,它必须知道每个人的一切.在控制台应用程序中,您的启动项目通常非常非常精简,并且包含的​​内容不多,只是组合根.由于ASP.NET应用程序的体系结构,这通常更难实现,例如因为启动项目是Web应用程序,它包含需要解决的各种类型(控制器,视图等).因此,Web应用程序通常将Composition Root集成到Web项目本身中.同样,这不是一件值得担心的事情,因为事实并不能使你的代码更加紧密耦合.

然而,当您有一个业务层被多个终端应用程序(例如WCF Web服务和MVC应用程序)重用时,情况会有所不同.为了防止代码重复,您可以将共享注册移出MVC和WCF组合根,并将其放在位于业务层(以及下面所有层)顶部的特殊“引导程序”程序集中.这可以简单到具有静态方法的静态类,该方法接收现有的内核实例并进行与业务相关的注册(大多数DI框架具有此功能,但在大多数情况下它们是无用的并且是静态公共的方法会做得很好).每个组合根可以创建自己的内核实例,进行注册,将实例传递给BL引导程序,然后执行更多注册,并存储内核供应用程序使用.

但即使有多个终端应用程序,它们仍将各自包含自己的特定接线(因为每个应用程序都不同),因此有自己的组合根.

点赞