我正在启动一个vNext项目,并且我有一些问题已经开始了。我已经在ApplicationDbContext
类中添加了一个表,它在db中成功创建了表(在我的例子中是在Azure中)。但是,我似乎无法正确实例化我的控制器中使用的dbContext
。
根据我以前的ASP.NET EF项目的经验,我可以实例化ApplicationDbContext类而不传递任何参数,但是在vNext的情况下,它似乎期待很多事情(IServiceProvider
,和IOptionsAccessor<DbContextOptions>
)。我已经尝试创建一个无参数构造函数,但由于不知道要使用哪些连接字符串而导致应用程序中断。我的代码如下所示 - 正如您在OnConfiguring(DbContextOptions options)
覆盖中看到的那样,我通过DbContextOptions
强制连接字符串,但这显然不太理想,我觉得我是&#39;我只是不明白那两个IServiceProvider
和IOptionsAccessor参数需要来自哪里。
感谢您的帮助!
namespace Project.Models
{
// Add profile data for application users by adding properties to the ApplicationUser class
public class ApplicationUser : IdentityUser
{
public string CompanyName { get; set; }
}
public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
private static bool _created = false;
public DbSet<Business> Businesses { get; set; }
public ApplicationDbContext()
: base()
{
if (!_created)
{
Database.EnsureCreated();
_created = true;
}
}
protected override void OnConfiguring(DbContextOptions options)
{
var configuration = new Configuration();
configuration.AddJsonFile("config.json");
configuration.AddEnvironmentVariables();
options.UseSqlServer(configuration.Get("Data:DefaultConnection:ConnectionString"));
}
public ApplicationDbContext(IServiceProvider serviceProvider, IOptionsAccessor<DbContextOptions> optionsAccessor)
: base(serviceProvider, optionsAccessor.Options)
{
// Create the database and schema if it doesn't exist
// This is a temporary workaround to create database until Entity Framework database migrations
// are supported in ASP.NET vNext
if (!_created)
{
Database.EnsureCreated();
_created = true;
}
}
}
}
答案 0 :(得分:1)
IServiveProvider和IOptionAccessor由依赖注入注入 ASP.Net Core DI有限制,你不能有多个构造函数。
阅读本文:http://blogs.msdn.com/b/webdev/archive/2014/06/17/dependency-injection-in-asp-net-vnext.aspx