依赖项注入-使用InRequestScope与Ninject进行Hangfire



我已经安装了Hangfire。Ninject包到ASP MVC 5应用程序中,这样我就可以运行一些后台作业。

我已经通读了文档,但我对如何实现它感到困惑

我现有的配置对我的IUnitOfwork类使用InRequestScope,以确保每个HTTP请求只实例化一个实例,如下所示:

private static void RegisterServices(IKernel kernel)
{
        kernel.Bind<IUnitOfWork>().To<UnitOfWork>().InRequestScope();
 } 

在遵循文档后,为了将ninject与hangfire一起使用,我在ninjectwebcommon.cs类中更新了如下配置:

 private static IKernel CreateKernel()
 {
        var kernel = new StandardKernel();
        try
        {
            kernel.Bind<Func<IKernel>>().ToMethod(ctx => () => new Bootstrapper().Kernel);
            kernel.Bind<IHttpModule>().To<HttpApplicationInitializationHttpModule>();
            GlobalConfiguration.Configuration.UseNinjectActivator(kernel);
            RegisterServices(kernel);
        return kernel;
        }
        catch
        {
            kernel.Dispose();
            throw;
        }
    }
    private static void RegisterServices(IKernel kernel)
    {
         kernel.Bind<IUnitOfWork>()
            .ToSelf()
            .InNamedOrBackgroundJobScope(context => context.Kernel.Components.GetAll<INinjectHttpApplicationPlugin>()
            .Select(c => c.GetRequestScope(context))
            .FirstOrDefault(s => s != null));
    }

但现在我得到以下错误:

Error activating IUnitOfWork using self-binding of IUnitOfWork
No constructor was available to create an instance of the implementation type.

我有一个类,我想使用hangfire来处理我的背景工作,如下所示:

 public class EmailJob
{
    private readonly IUnitOfWork _unitOfWork;
    private readonly IMailer _mailer;
    public EmailJob(IUnitOfWork unitOfWork, IMailer mailer)
    {
        _unitOfWork = unitOfWork;
        _notificationMailer = notificationMailer;
    }
     public void Execute()
    {
        // DO Stuff
    }
}

有人知道我做错了什么吗?文件还指出:

Services registered with InRequestScope() directive will be unavailable during job activation, you should re-register these services without this hint.

这是什么意思?我仍然希望确保每个http请求只使用一个实现dbContext的IUnitOfwork类。如果我删除InRequestScope,这将如何影响应用程序的其余部分?

我认为问题在于您正在将IUnitOfWork绑定到它自己。Niject需要一个具体的类来激活类似UnitOfWork的东西。

  kernel.Bind<IUnitOfWork>()
        .To<UnitOfWork()
        .InNamedOrBackgroundJobScope(context => context.Kernel.Components.GetAll<INinjectHttpApplicationPlugin>()
        .Select(c => c.GetRequestScope(context))
        .FirstOrDefault(s => s != null));

最新更新