InvalidOperationException:尝试激活“ OESAC.Pages.Courses.IndexModel”时无法解析类型为“ OESAC.Data.MyDbContext”的服务

时间:2019-03-30 06:32:42

标签: sqlite dbcontext razor-pages

我已经在StackOverflow和整个世界中寻找解决方案。可以肯定的是,如果这是一条蛇,它会咬我。 VS 2017 Razor Pages Web应用程序运行并显示主页。我想显示连接到“课程”表的“页面/课程/Index.chstml”页面。当我单击“课程”链接时,即一切崩溃。

这是我的“ MyDbContext”类:

using Microsoft.EntityFrameworkCore;

namespace OESAC.Data
{
    public class MyDbContext : DbContext
    {
        public DbSet<Courses> Courses { get; set; }
        public DbSet<Sponsors> Sponsors{ get; set; }

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseSqlite(@"Data source=oesac_new.db");
        }
    }
}

这是正在触发错误的索引文件。它在Pages.Courses文件夹中:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.RazorPages;
using Microsoft.EntityFrameworkCore;
using OESAC.Data;

namespace OESAC.Pages.Courses
{
    public class IndexModel : PageModel
    {
        private readonly OESAC.Data.MyDbContext _context;

        public IndexModel(OESAC.Data.MyDbContext context)
        {
            _context = context;
        }

        public List<OESAC.Data.Courses> Courses { get;set; }

        public async Task OnGetAsync()
        {
            Courses = await _context.Courses.ToListAsync();
        }
    }
}

这是错误:

System.InvalidOperationException: Unable to resolve service for type 'OESAC.Data.MyDbContext' while attempting to activate 'OESAC.Pages.Courses.IndexModel'.
   at Microsoft.Extensions.DependencyInjection.ActivatorUtilities.GetService(IServiceProvider sp, Type type, Type requiredBy, Boolean isDefaultParameterRequired)
   at lambda_method(Closure , IServiceProvider , Object[] )
   at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.DefaultPageModelActivatorProvider.<>c__DisplayClass1_0.<CreateActivator>b__0(PageContext context)
   at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.DefaultPageModelFactoryProvider.<>c__DisplayClass3_0.<CreateModelFactory>b__0(PageContext pageContext)
   at Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.CreateInstance()
   at Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
   at Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.InvokeInnerFilterAsync()
   at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeNextResourceFilter()
   at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Rethrow(ResourceExecutedContext context)
   at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
   at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeFilterPipelineAsync()
   at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeAsync()
   at Microsoft.AspNetCore.Routing.EndpointMiddleware.Invoke(HttpContext httpContext)
   at Microsoft.AspNetCore.Routing.EndpointRoutingMiddleware.Invoke(HttpContext httpContext)
   at Microsoft.AspNetCore.StaticFiles.StaticFileMiddleware.Invoke(HttpContext context)
   at Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)

1 个答案:

答案 0 :(得分:0)

好的,我开始排除错误,并得到了一些帮助。

我发现了这个问题,并将其添加到了Startup.cs ConfigureServices

.NET Core中的所有内容都是围绕依赖项注入构建的,而不是使用诸如ConfigurationManager之类的静态实例。 您可以通过几种不同的方式来执行此操作。 首先将使用以下方法在Startup.cs ConfigureServices中注册DbContext:

services.AddDbContext<MyDbContext>(options => options.UseSqlite(Configuration.GetConnectionString("DefaultConnection")));

以下是上述问答的位置: How to pass connection string from appsettings.[name].json to DbContext in .NET Core?

================================================ ====

我必须添加的第二项是在另一个线程中找到的(我更改了上下文名称以反映我的MyDbContext):

如错误所示,如果您通过AddDbContext配置MyDbContext,则还需要向MyDbContext类中添加一个接收DbContextOptions类型参数的构造函数,如下所示:

public MyDbContext(DbContextOptions<MyDbContext> options)
    : base(options)
{ }

如果您不这样做,ASP.Net Core将无法注入您使用AddDbContext设置的配置。(请记住我在第一个URL中回答的答案:“ Everything in。 NET Core是围绕依赖项注入构建的,而不是使用静态实例”。自我注意:了解什么是依赖注入LOL

走吧。您会认为脚手架会完成所有这一切。真是头疼。

我再次在StackOverflow上发现了这一点:

AddDbContext was called with configuration, but the context type 'MyContext' only declares a parameterless constructor?