for*_*tIO 12 .net c# asp.net .net-core-2.0
我已经在SO上看到了一些关于这方面的类似例子,但是我还不太了解该语言,看看我做错了什么.我拼凑了一个演示来了解更多,但我在播种数据库时遇到了麻烦.
我收到以下错误:
InvalidOperationException:无法从根提供程序解析作用域服务"demoApp.Models.AppDbContext".
Microsoft.Extensions.DependencyInjection.ServiceLookup.CallSiteValidator.ValidateResolution(类型serviceType,ServiceProvider serviceProvider)
以下是有问题的三个文件:
型号/ AppDbContext.cs
public class AppDbContext : DbContext
{
public AppDbContext(DbContextOptions<AppDbContext> options) : base(options)
{
}
public DbSet<Product> Products{ get; set; }
public DbSet<Category> Categories { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
型号/ DBInitializer.cs
public static class DbInitializer
{
public static void Seed(IApplicationBuilder applicationBuilder)
{
//I'm bombing here
AppDbContext context = applicationBuilder.ApplicationServices.GetRequiredService<AppDbContext>();
if (!context.Products.Any())
{
// Add range of products
}
context.SaveChanges();
}
private static Dictionary<string, Category> _categories;
public static Dictionary<string, Category> Categories
{
get
{
if (_categories == null)
{
// Add categories...
}
return _categories;
}
}
}
Run Code Online (Sandbox Code Playgroud)
Startup.cs
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public IConfiguration Configuration { get; }
public void ConfigureServices(IServiceCollection services)
{
services.AddTransient<ICategoryRepository, CategoryRepository>();
services.AddTransient<IProductRepository, ProductRepository>();
services.AddDbContext<AppDbContext>(options =>
options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
services.AddMvc();
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
app.UseBrowserLink();
app.UseStatusCodePages();
// Kersplat!
DbInitializer.Seed(app);
}
else ...
app.UseStaticFiles();
app.UseMvc(routes => {...});
}
Run Code Online (Sandbox Code Playgroud)
有人可以帮助解释我做错了什么以及如何纠正这种情况?
Les*_*s P 31
在ASP.NET Core 2.0中,建议进行以下更改.(在startup.cs中播种适用于Core 1.x.对于2.0进入Program.cs,修改Main方法以在应用程序启动时执行以下操作:从依赖注入容器中获取数据库上下文实例.调用种子方法,传递上传.在种子方法完成时处理上下文.(以下是Microsoft站点的示例.https://docs.microsoft.com/en-us/aspnet/core/data/ef-mvc/intro)
public static void Main(string[] args)
{
var host = BuildWebHost(args);
using (var scope = host.Services.CreateScope())
{
var services = scope.ServiceProvider;
try
{
var context = services.GetRequiredService<yourDBContext>();
DbInitializer.Seed(context);//<---Do your seeding here
}
catch (Exception ex)
{
var logger = services.GetRequiredService<ILogger<Program>>();
logger.LogError(ex, "An error occurred while seeding the database.");
}
}
host.Run();
}
Run Code Online (Sandbox Code Playgroud)
从原始答案更新:
对于.NET 2.0的核心,看看这个答案,而不是
原答案:
我也不是.NET核心专家,但这可能是你的解决方案.
在DBInitializer.cs中
public static void Seed(IApplicationBuilder applicationBuilder)
{
using (var serviceScope = applicationBuilder.ApplicationServices.GetRequiredService<IServiceScopeFactory>()
.CreateScope())
{
AppDbContext context = serviceScope.ServiceProvider.GetService<AppDbContext>();
if (!context.Products.Any())
{
// Seed Here
}
context.SaveChanges();
}
}
Run Code Online (Sandbox Code Playgroud)
该错误表明上下文应该是作用域.
此外,如果您还没有这样做,我将查看ASP.NET Core doc中的依赖注入简介,但更具体地说,请参阅" 服务生命周期和注册选项"部分.
归档时间: |
|
查看次数: |
24130 次 |
最近记录: |