Для этого DbContext не настроен поставщик базы данных - ASP.Net Core 2.1 - PullRequest
0 голосов
/ 22 ноября 2018

Я получаю следующую ошибку:

InvalidOperationException: для этого DbContext не настроен поставщик базы данных.Поставщик может быть настроен путем переопределения метода DbContext.OnConfiguring или с помощью AddDbContext в поставщике службы приложений.Если используется AddDbContext, также убедитесь, что ваш тип DbContext принимает объект DbContextOptions в своем конструкторе и передает его базовому конструктору для DbContext.

Startup.cs:

public void ConfigureServices(IServiceCollection services)
{
    services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();
    services.AddDistributedMemoryCache();
    services.AddSession(options=>{options.IdleTimeout = TimeSpan.FromMinutes(1);});services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme).AddCookie(options =>
        {
            options.Cookie.HttpOnly = true;
            options.ExpireTimeSpan = TimeSpan.FromMinutes(20);
            options.Cookie.Name = "SampleCore";
            options.LoginPath = "/log-in";
            //options.AccessDeniedPath = "/access-denied";
            options.LogoutPath = "/log-off";
            options.ReturnUrlParameter = "postBack";
        });
    services.AddMvc(options =>
        {
            options.Filters.Add(new AutoValidateAntiforgeryTokenAttribute());
        }).SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
    string connection = Configuration.GetConnectionString("MyConnection");
    services.AddDbContext<EmployeeContext>(options => options.UseSqlServer(connection), ServiceLifetime.Scoped);   
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    app.UseStaticFiles();
    app.UseSession();
    app.UseCookiePolicy();
    app.UseAuthentication();
    app.UseCustomErrorPages();
    app.UseMvc();
}

Расширение UseCustomErrorPages:

public async Task Invoke(HttpContext context)
    {
        await _next(context); // Getting error at this line
        if (context.Response.StatusCode == 404 && !context.Response.HasStarted)
        {
            string originalPath = context.Request.Path.Value;
            context.Items["originalPath"] = originalPath;
            context.Request.Path = "/page-not-found";
            await _next(context);
        }
        else if (context.Response.StatusCode == 500)
        {
            string originalPath = context.Request.Path.Value;
            context.Items["originalPath"] = originalPath;
            context.Request.Path = "/error";
            await _next(context);
        }
        else if(context.Response.StatusCode == 401)
        {
            string originalPath = context.Request.Path.Value;
            context.Items["originalPath"] = originalPath;
            context.Request.Path = "/access-denied";
            await _next(context);
        }
    }

DbContext:

public partial class EmployeeContext : DbContext
{
    public EmployeeContext(DbContextOptions<EmployeeContext> options)
        : base(options)
    {
    }

    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        if (!optionsBuilder.IsConfigured)
        {
            var connectionString = "connectionString";
            optionsBuilder.UseSqlServer(connectionString);
            base.OnConfiguring(optionsBuilder);
        }
    }

    public virtual DbSet<TblEmployee> TblEmployee { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        //Code
    }
}

Файл csproj:

<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore.App" />
<PackageReference Include="Microsoft.AspNetCore.Razor.Design" Version="2.1.2" PrivateAssets="All" />
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="2.1.4" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="2.1.4" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer.Design" Version="1.1.6" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="2.1.4">
  <PrivateAssets>all</PrivateAssets>
  <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>
<PackageReference Include="Microsoft.VisualStudio.Web.CodeGeneration.Design" Version="2.1.6" />

Контроллер:

private EmployeeContext _context;
public HomeController(EmployeeContext context)
{
    _context = context;
}
public List<TblEmployee> GetEmployees
{
   List<TblEmployee> getEmployees = _context.TblEmployee.ToList();
   return getEmployees ;
}

appsettings.json:

{
  "Logging": {
  "LogLevel": {
  "Default": "Warning"
  }
 },
"ConnectionStrings": {
"MyConnection": "connection string"
},
"AllowedHosts": "*"
}

Я не понимаю, где я поступил неправильно.Пожалуйста, помогите

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...