Невозможно создать DbSet для ApplicationUser, поскольку этот тип не включен в модель для контекста. - PullRequest
0 голосов
/ 26 марта 2019

При попытке добавить нового пользователя, используя ядро ​​Entity Framework, я получаю приведенный выше код ошибки.Я знаю, что здесь уже задавался этот вопрос, но я не могу решить мою проблему с помощью решений, которые я нашел до сих пор.

Я пытаюсь создать пользователя с именем пользователя (адрес электронной почты) и паролем, используя asp.netидентичности, но я продолжаю получать следующее сообщение об ошибке:

"InvalidOperationException: невозможно создать DbSet для ApplicationUser ', так как этот тип не включен в модель для контекста."

Я пытался связываться с файлом startup.cs и файлом Model.BlogContext, как это рекомендуется для нескольких потоков, но не могу обойти это сообщение.

Я довольно новичок в этом,извините, если мой вопрос не ясен.

Вот мой код -

ApplicationContext:

пространство имен Blog3Prog.Models {class Message {[Key]public int MessageId {get;задавать;} публичная строка UserName {get;задавать;} публичная строка FullMessage {get;задавать;}

}
class Timeline
{
    [Key]
    public int UserId { get; set; }
    public int Posts { get; set; }
    public string Username { get; set; }
}
public class BlogContext : IdentityDbContext<ApplicationUser>
{
    public BlogContext(DbContextOptions<DbContext> options) : base()
    {

    }
        protected override void OnConfiguring(DbContextOptionsBuilder 
optionsBuilder)
        {

            optionsBuilder.UseSqlServer(@"Data Source= 
(localdb)\MSSQLLocalDB;Initial Catalog=master;Integrated 
Security=True;Connect 
Timeout=30;Encrypt=False;TrustServerCertificate=False; 
ApplicationIntent=ReadWrite;MultiSubnetFailover=False; Database=BlogProject 
;Trusted_Connection=True");
        }
        private DbSet<Message> Messages { get; set; }
        private DbSet<Timeline> Timelines { get; set; }
        private DbSet<ApplicationUser> applicationUsers { get; set; }
        public DbSet<Microsoft.AspNetCore.Identity.IdentityUserClaim<Guid>> 
IdentityUserClaims { get; set; }
        public DbSet<IdentityUserClaim<string>> IdentityUserClaim { get; 
set; }
        public new DbSet<ApplicationUser> Users { get; set; }
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {

        }
    }
}

Startup.cs:

namespace Blog3Prog
{

public class Startup
{
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }

    public IConfiguration Configuration { get; }

    // This method gets called by the runtime. Use this method to add 
services to the container.
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddDbContext<BlogContext>(options =>
 options.UseSqlServer(@"Data Source=(localdb)\MSSQLLocalDB;Initial 
Catalog=master;Integrated Security=True;Connect 

Timeout=30;Encrypt=False;TrustServerCertificate=False; 
ApplicationIntent=ReadWrit 
e;MultiSubnetFailover=False; Database=BlogProject 
;Trusted_Connection=True"));

        services.Configure<CookiePolicyOptions>(options =>
        {

            // This lambda determines whether user consent for non-essential 
cookies is needed for a given request.
            options.CheckConsentNeeded = context => true;
            options.MinimumSameSitePolicy = SameSiteMode.None;

        });

        services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();

        services.AddIdentity<Blog3Prog.Models.ApplicationUser, 
IdentityRole> ()
            .AddEntityFrameworkStores<DbContext>()
            .AddDefaultTokenProviders();

        services.AddMvc().SetCompatibilityVersion 
 (CompatibilityVersion.Version_2_2);
    }

    // This method gets called by the runtime. Use this method to configure 
the HTTP request pipeline.
    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
        else
        {
            app.UseExceptionHandler("/Home/Error");
            // The default HSTS value is 30 days. You may want to change 
this for production scenarios, see https://aka.ms/aspnetcore-hsts.
            app.UseHsts();
        }

        app.UseHttpsRedirection();
        app.UseStaticFiles();
        app.UseCookiePolicy();

        app.UseMvc(routes =>
        {
            routes.MapRoute(
                name: "default",
                template: "{controller=Account}/{action=Login}/{id?}");
        });
        app.UseAuthentication();
    }
  }
}

Контроллер:

namespace Blog3Prog.Controllers
{
public class AccountController : Controller
{

    public readonly UserManager<ApplicationUser> _userManager;
    public readonly SignInManager<ApplicationUser> _signInManager;
    public readonly Models.BlogContext _context;

    public AccountController(UserManager<ApplicationUser> userManager
                            ,SignInManager<ApplicationUser> signInManager
                            , Models.BlogContext context)
    {
        _userManager = userManager;
        _signInManager = signInManager;
        _context = context;

    }
    [HttpGet]
    public IActionResult Register()
    {

        return View();
    }

    [HttpPost]
    public async Task<IActionResult> Register(RegisterViewModel vModel)
    {
        if (ModelState.IsValid)
        {
            var user = new ApplicationUser { UserName = vModel.UserEmail, Email = vModel.UserEmail };
            var result = await _userManager.CreateAsync(user, vModel.Password);
            if (result.Succeeded)
            {
                //await _signInManager.SignInAsync(user, false);
                //return RedirectToAction("Index", "Home");
            }
            else
            {
                foreach (var error in result.Errors)
                {
                    ModelState.AddModelError("", error.Description);
                }
            }
        }
        return View(vModel);
    }



    public IActionResult Login()
    {
        return View("Login");
    }
  }
}   

Просмотр

<h2>Registration Page</h2>

<form method="post" asp-controller="Account" asp-action="Register">
<div asp-validation-summary="All"></div>
<div>
    <label asp-for="UserEmail"></label>
    <input asp-for="UserEmail" />
    <span asp-validation-for="UserEmail"></span>
</div>
<div>
    <label asp-for="Password"></label>
    <input asp-for="Password" />
    <span asp-validation-for="Password"></span>
</div>
<div>
    <label asp-for="ConfirmPassword"></label>
    <input asp-for="ConfirmPassword" />
    <span asp-validation-for="ConfirmPassword"></span>
</div>
<div>
    <input type="submit" value="Register" />
</div>


</form>

ApplicationUser.cs

using Microsoft.AspNetCore.Identity;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace Blog3Prog.Models
{
  public class ApplicationUser:IdentityUser
  {
    public int UserId { get; set; }
    public string UserEmail { get; set; }
    public DateTime CreatedOn { get; set; }
    public int Points { get; set; }
  }
}

1 Ответ

0 голосов
/ 26 марта 2019

Это выдает мне сообщение об ошибке: «Не существует неявного преобразования ссылок из« Blog3Prog.Models.BlogContext »в« Microsoft.EntityFrameworkCore.DbContext ».

Такое поведение появилосьпотому что BlogContext не унаследовал IdentityDbContext

Вот мой пример ниже. Этот пример работает на моем локальном компьютере. Измените User с вашим ApplicationUser и добавьте другие ваши модели.

public class BlogContext : IdentityDbContext<User>
    {
        public BlogContext(DbContextOptions options) : base()
        {

        }
        public DbSet<User> Users { get; set; }
    }

public class User:IdentityUser
    {
    }

Это должно быть добавленодля настройки служб.

services.AddDbContext<BlogContext>(options =>
                options.UseSqlServer("Your connection string");

Я думаю, что создание контекста БД, как вы это сделали, является плохой идеей.

Также удалите следующее из вашего запуска:

services.AddScoped<BlogContext>();
services.AddScoped<DbContext>();

Вот как можно реорганизовать свой BlogContext.cs:

public class BlogContext : IdentityDbContext<ApplicationUser>
    {
        public BlogContext(DbContextOptions options) : base()
        {

        }

        public DbSet<Message> Messages { get; set; }
        public DbSet<Timeline> Timelines { get; set; }
        public DbSet<ApplicationUser> applicationUsers { get; set; }
        public DbSet<IdentityUserClaim<Guid>> IdentityUserClaims { get; set; }
        public DbSet<IdentityUserClaim<string>> IdentityUserClaim
        {
            get;
            set;
        }

    }
...