在ASP.NET MVC5中使用Ninject注入实体框架DbContext

s.k*_*aul 2 entity-framework ninject asp.net-mvc-5

我刚刚登陆依赖注入世界.

我有以下自定义DbContext-

public partial class SkyTrackerContext: DbContext
{
    public SkyTrackerContext(): base()
    {
        Database.SetInitializer(new SkyTrackerDBInitializer());
    }
}
Run Code Online (Sandbox Code Playgroud)

想在这个基础控制器中注入SkyTrackerContext-

public abstract class BaseController : Controller
{
    public BaseController() {}

    [Inject]
    public SkyTrackerContext MyDbContext { get; set; }
 }
Run Code Online (Sandbox Code Playgroud)

样品用法 -

public class LoginController : BaseController
{            
    public ActionResult ValidateLogin(Login login) 
    {
      var query = MyDbContext.Persons.Where(.....);
    }
}
Run Code Online (Sandbox Code Playgroud)

我应该在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>();

        RegisterServices(kernel);
        return kernel;
     }
     catch
     {
         kernel.Dispose();
         throw;
     }
}
Run Code Online (Sandbox Code Playgroud)

Chr*_*att 5

首先,你应该避免方法注入.相反,使用构造函数注入.换一种说法:

public abstract class BaseController : Controller
{
    protected readonly DbContext context;

    public BaseController(DbContext context)
    {
        this.context = context;
    }

    ...
}
Run Code Online (Sandbox Code Playgroud)

然后,就Ninject配置而言,它非常简单:

kernel.Bind<DbContext>().To<SkyTrackerContext>().InRequestScope();
Run Code Online (Sandbox Code Playgroud)

  • 假设`SkyTrackerContext`有一个属性`public DbSet <Track> Tracks {get; 组; 你怎么能创建像`context.Tracks.Where这样的链接查询(t => t.Id == 1);`?我同意依赖关系不应该知道或关心它是如何实现的,但它应该有一个有用的接口来与之通信.默认的DbContext不提供对实体的任何访问,或者它是什么? (2认同)