1

我的问题实际上是在这里发布的一个老问题的重复: Ninject 2.2 multiple bindings

似乎有人要在 2011 年处理这个问题。有谁知道是否有办法在 Ninject 中关闭此类警告?还是其他一些解决方法?

编辑

作为对@BatteryBackupUnit 的回应,这是我的确切问题:

我有多个库......在我的核心库中,我做了这样的事情:

  1. 查找宿主应用程序(包括宿主)引用的所有程序集
  2. IDependency查找从所有这些程序集继承的所有类型。
  3. 自动将所有这些注册为瞬态

然后从另一个库(主机应用程序可能会或可能不会引用),我有这个:

Kernel.Bind<IDbContextFactory>().To<DbContextFactory>().InSingletonScope();

这里IDbContextFactory也是一个IDependency,所以它已经被核心库加载了,现在我在这里注册它,但范围不同(单例)。

根据经验(并且之前已经测试过),我知道这在 Autofac 中没有问题,但是 Ninject 给了我关于已经注册它的错误消息。

理想情况下,最好只覆盖任何以前的注册......“级联风格”(因为缺乏更好的短语)......

4

1 回答 1

0

Ninject 现在支持用更具体的绑定覆盖开放的通用绑定。例如:

public interface IFoo<T> { }
public class Foo<T> : IFoo<T> { }
public class StringFoo : IFoo<string> {}

像这样使用:

var kernel = new StandardKernel();
kernel.Bind(typeof(IFoo<>)).To(typeof(Foo<>));
kernel.Bind<IFoo<string>>().To<StringFoo>();

var intFooInstance = kernel.Get<IFoo<int>>();
var stringFooinstance = kernel.Get<IFoo<string>>();

作品。

然而,如果你不是在谈论开放的泛型绑定,ninject 3 仍然处理与 ninject 2.2 相同的多绑定。

在大多数情况下,您可以通过使用上下文绑定来解决此问题。好吧,我不会把它称为一种解决方法,我会称之为好的设计。一般来说,这在这里描述:https ://github.com/ninject/ninject/wiki/Contextual-Binding

一种简单的方法是使用名称指定绑定。这需要一个绑定到指定的绑定,并且也只允许绑定一个。请参阅:https ://github.com/ninject/ninject/wiki/Contextual-Binding#simple-constrained-resolution-named-bindings

也可以使用以下语法定义“默认”绑定.Bind<IFoo>().To<Foo>();和特殊情况绑定,例如:.When(...)

.Bind<IFoo>().To<SpecialFoo>().When(ctx => ...)

请参阅https://github.com/ninject/ninject/wiki/Contextual-Binding#specifying-constraints-on-the-type-binding-using-arbitrary-elements-of-the-resolution-request-context

如果您向我们展示您的具体问题,我们也许能够提供更具体的解决方案。

于 2014-02-05T12:49:47.310 回答