- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个抽象类:
public abstract class Validator<T> : IValidator
以及一些为特定目的实现此类的类,例如
public sealed class NewsValidator : Validator<News>
现在使用 Ninject 我想像下面这样进行依赖注入(inject)(这个特定的代码不起作用):
Bind<Validator<News>>().To<NewsValidator>();
Bind(typeof(Validator<>)).To(typeof(NullValidator<>));
所以我想实现的是
Validator<News>
应该绑定(bind)到类“NewsValidator”,但是如果请求这个类的任何其他未绑定(bind)版本,比如
Validator<Article>
Validator<SomethingElse>
应该绑定(bind)到默认类 (NullValidator)。但是,使用上面使用的代码会引发异常,因为它将验证器
我该如何实现?泛型类的特定类型应该绑定(bind)到各个类。未显式绑定(bind)的泛型类的所有其他类型都应绑定(bind)到默认类。
如果有一些建议,我会非常高兴!谢谢!
最佳答案
您可以创建 IMissingBindingResolver 的自定义实现.
每当内核无法解析所请求服务的绑定(bind)时,它就会委托(delegate)给 HandleMissingBinding方法(这适用于从 KernelBase 派生的任何内核)。 HandleMissingBinding 方法将询问每个缺少的绑定(bind)解析器是否可以为请求的服务创建绑定(bind)。解析器返回的绑定(bind)(如果有)将添加到内核中。
请注意,由缺失的绑定(bind)解析器创建的任何绑定(bind)都将作为隐式绑定(bind)添加到内核中。这可能会对您的申请产生影响。例如,如果您混合使用服务的显式和隐式绑定(bind),解析这些绑定(bind),即 kernel.GetAll<TService>()
, 仅解析显式绑定(bind)。但是,如果所有绑定(bind)都是隐式的,它们都将被解析。
Ninject 有两个 IMissingBindingResolver 的标准实现:
让我们为 null 验证器实现自定义解析器。
public class MissingValidatorResolver : NinjectComponent, IMissingBindingResolver
{
public IEnumerable<IBinding> Resolve(
Multimap<Type, IBinding> bindings, IRequest request)
{
var service = request.Service;
if (!typeof(IValidator).IsAssignableFrom(service))
{
return Enumerable.Empty<IBinding>();
}
var type = service.GetGenericArguments()[0];
var validatorType = typeof(NullValidator<>).MakeGenericType(type);
var binding = new Binding(service)
{
ProviderCallback = StandardProvider.GetCreationCallback(validatorType)
};
return new[] { binding };
}
}
现在下面的测试(使用 xUnit.net )通过了。
[Fact]
public void ShouldResolveNonBoundValidatorDerivedFromValidatorAsNullValidator()
{
var kernel = new StandardKernel();
kernel.Components.Add<IMissingBindingResolver, MissingValidatorResolver>();
var validator = kernel.Get<Validator<Article>>();
Assert.IsType<NullValidator<Article>>(validator);
}
关于c# - Ninject:通用类的默认和特定绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6219560/
有人在 monodroid 项目中使用 ninject 吗? 如果是这样,将不胜感激有关实现这一目标的任何指示/细节。 最佳答案 我还没有尝试在 Mono For Android 中使用 Ninjec
我找到了this article关于 Ninject 早期版本中的上下文变量。我的问题有两个方面。首先,如何使用 Ninject 2 获得这种行为?其次,上下文变量是否沿着请求链传递?例如,假设我想替
我有一个场景,只要一个对象上的方法返回 true,多个并发 Web 请求就应该重用一个对象。有问题的对象是线程安全的。 所以我需要当前范围内的对象来确定它是否仍在范围内。使用 Ninject 完成此任
我刚刚使用 Ninject 3 更新了我的应用程序。将 App_Start 中的文件从 NinjectMVC3 更改为 NinijectWebCommon.cs。移动了我的文件,更新了 DLLs..
我在 MVC4 应用程序中使用 Ninject 进行 DI 和 Ninject.MVC3 扩展,特别是版本 3.0.0.6。 阅读documentation在 Ninject 的 wiki 上,使用
如何绑定(bind)InitializerForXXX (非通用实现)到 IInitializer (通用接口(interface))使用 Ninject Conventions以便请求 IIniti
我正在开发一个框架扩展,它使用 Ninject 作为 IoC 容器来处理动态注入(inject),但是我在尝试解决如何实现这一点时遇到了一些麻烦。 我的框架的期望是您将传递 IModule(s)所以它
我确信这是一个愚蠢的问题,因为我假设答案是“当对象被 Ninject 实例化时”......但我想仔细检查...... 为了提供更多关于我为什么问这个问题的背景信息,我有一个实现 NinjectHtt
与其手动绑定(bind)每个类,不如推荐哪些方法和模式(如果有)来自动设置绑定(bind)? 例如,绝大多数绑定(bind)看起来像这样: Bind.To(); 一旦模块变大,您最终可能会得到 100
我试图找到一种将构造函数参数传递给子类的构造函数的方法。 这些对象是不可变的,所以我更喜欢使用构造函数参数。 我遇到的问题是 ConstructorArgument 不继承到子实例化,并且以下语句不可
我正在尝试为事件代理/消息代理的开发找到最新的 Ninject 扩展。 我至少可以找到 3 个:messagebroker , weakeventmessagebroker和 bbveventbrok
我有一个 WebApi 服务,我正在尝试使用 Ninject BindHttpFilter 添加身份验证。 使用 BindHttpFilter 允许我将身份验证过滤器绑定(bind)到特定属性。 Au
Autofac 自动为 Func 生成工厂;我什至可以传递参数。 public class MyClass { public MyClass(Func a, Func b) {
我有一个类需要为其类中的一个方法使用 IRepository。 理想情况下,我希望避免将这种依赖关系解析到类的构造函数中,因此我在 Ninject 中发现了方法级注入(inject),并且想知道这是如
我看到了枚举给定服务(类型)的绑定(bind)列表的方法,但我找不到返回已加载模块中绑定(bind)的所有内容列表的方法。我正在寻找类似Kernel::IEnumerable GetAllRegist
对于初学者,我正在使用这个模块: public class AutoMapperModule : NinjectModule { public override void Load()
我想知道 ninject 是否有可能拦截我类的私有(private)方法。我正在尝试进行一些 aop 编程以动态注入(inject)日志记录机制。 最佳答案 不幸的是,所有要拦截的方法都必须是virt
我是 Ninject 的新手,正在努力让这个测试通过。 (此测试通过 Autofac,但行为在 Ninject 中似乎有所不同)。 [Test] public void RegisterInstanc
我在一个小项目中使用过 Ninject,但现在正在将一个较大的 Web 应用程序转换为 mvc,并且需要有关使用 Ninject 的帮助。在新的解决方案中,我拥有 mvc 站点并将一些功能拆分到单独的
目前,我正在使用 ninject 执行以下绑定(bind)的命令模式: kernel.Bind>().To(); kernel.Bind>().To(); kernel.Bind>().To(); 我
我是一名优秀的程序员,十分优秀!