asp.net-mvc – Ninject – 具有参数/ Entity Framework连接字符串的绑定构造函数

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – Ninject – 具有参数/ Entity Framework连接字符串的绑定构造函数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
请原谅我的无知,但我对IOC和NinJect很新.我已经寻找到高低的易于理解的解决方案,但到目前为止,他们已经逃避了我.

到目前为止,我有以下和所有的工作如预期:

private class StandardModule : NinjectModule
    {
      public override void Load()
      {
        Bind<ILog>().To<NLogLogger>();    // Use NLog
        Bind<IMyEntityFrameWorkRepository().To<MyEntityFrameWorkRepository>();
      }
    }

MyEntityFrameWorkRepository然后通过app / web.config中声明的连接字符串创建自己的EF DbContext:

public class MyDbContext : DbContext
{
   public MyDbContext() : base("MyAppConfig")
   {
   }
   ........
}

然而!!我的目标是这样的 – 我意识到这种语法是“废话”(我想我也可能需要IOC MyDbConext),但我希望“伪代码”传达我的愿望:

private class StandardModule : NinjectModule
{
  public override void Load()
  {
    Bind<ILog>().To<NLogLogger>();    // Use NLog

    string MysqLConnectionString = MyApp.GetCommandLineArgument("sqlconn"); // "Data Source=..."
    Bind<IMyEntityFrameWorkRepository().To<MyEntityFrameWorkRepository>(MysqLConnectionString);
  }
}

.................

public class MyDbContext : DbContext
{
   public MyDbContext( string sqlConnectionString) :
      base(sqlConnectionString) // will accept a standard sql connection string
   {
   }
   ........
}

我真的非常感谢IOC / NinJect专家的一些反馈意见,因为我确信任何“模式”在其他情况下都是非常有用的.

解决方法

您可以使用.WithConstructorArgument()方法来指定构造函数参数.第一个参数应该是构造函数参数的名称.
public class StandardModule : NinjectModule
{
    public override void Load()
    {
        string connectionString = "...";
        Bind<IMyEntityFrameWorkRepository().To<MyEntityFrameWorkRepository>()
            .WithConstructorArgument("sqlConnectionString",connectionString);
    }

}

猜你在找的asp.Net相关文章