Ошибка при попытке создания начальной миграции EF Core 3 asp.net Core - PullRequest
0 голосов
/ 12 октября 2019

У меня есть следующие классы:

public class Quiz 
    {
        public int Id { get; set; }
        public string Title { get; set; }
        public string Description { get; set; }
        public string UserToken { get; set; }
        public List<JoinQuizAndArea> AreasOfQuizzes { get; set; }
        public List<QuizQuestion> Questions { get; set; }
}
public class QuizQuestion
    {
        public int ListRanking { get; set; }
        public string Question { get; set; }
        public string Answer1 { get; set; }
        public string Answer2 { get; set; }
        public string Answer3 { get; set; }
        public int CorrectAnswer { get; set; }
        public int QuizId { get; set; }
        public Quiz Quiz { get; set; }
    }
public class AreaOfQuiz
    {
        public int Id { get; set; }
        public string Area { get; set; }
        public List<JoinQuizAndArea> AreasOfQuizzes { get; set; }
    }
public class JoinQuizAndArea
    {
        public int QuizId { get; set; }
        public Quiz Quiz { get; set; }
        public int AreaId { get; set; }
        public AreaOfQuiz Area { get; set; }

    }

и мой DbContext:

public class ApplicationDbContext : IdentityDbContext<IdentityUser>
    {
        public DbSet<IdentityUser> Users { get; set; }
        public DbSet<Quiz> Quizzes { get; set; }
        public DbSet<AreaOfQuiz> Areas { get; set; }
        public DbSet<QuizQuestion> Questions { get; set; }

        public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options) : base(options) { }
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.Entity<IdentityUser>();

            modelBuilder.Entity<Quiz>();

            modelBuilder.Entity<AreaOfQuiz>();

            modelBuilder.Entity<QuizQuestion>()
                .HasKey(quizQuestion => new { quizQuestion.QuizId, quizQuestion.ListRanking});

            modelBuilder.Entity<JoinQuizAndArea>()
                .HasKey(joinEntity => new { joinEntity.QuizId, joinEntity.AreaId });
            modelBuilder.Entity<JoinQuizAndArea>()
                .HasOne(join => join.Area)
                .WithMany(c =>c.AreasOfQuizzes)
                .HasForeignKey(join => join.QuizId);
            modelBuilder.Entity<JoinQuizAndArea>()
                .HasOne(bc => bc.Quiz)
                .WithMany(c => c.AreasOfQuizzes)
                .HasForeignKey(bc => bc.AreaId);

            base.OnModelCreating(modelBuilder);
        }
    }

, когда я пытаюсь создать начальную миграцию, я получил следующую ошибку: Ошибкапроизошло при доступе к службам Microsoft.Extensions.Hosting. Продолжая без поставщика услуг приложения. Ошибка: настраиваемая конфигурация для элементов поддерживается только для отдельных элементов верхнего уровня в типе. Невозможно создать объект типа «ApplicationDbContext». О различных шаблонах, поддерживаемых во время разработки, см. https://go.microsoft.com/fwlink/?linkid=851728 У кого-нибудь есть идеи, как решить эту проблему? Спасибо:)

Обновление Мой стартовый класс:

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.AddCors();

            services.AddControllers();

            var mappingConfig = new MapperConfiguration(mapConfig =>
            {
                mapConfig.AddProfile(new QuizProfile());
                mapConfig.AddProfile(new AreaOfQuizProfile());
                mapConfig.AddProfile(new QuizQuestionProfile());
                mapConfig.AddProfile(new QuizIdAreaIdToJoinQuizAndAreaProfile());
            });
            IMapper mapper = mappingConfig.CreateMapper();
            services.AddSingleton(mapper);

            services.AddDbContext<ApplicationDbContext>(options => options.UseSqlServer(Configuration["ConnectionString:QuizWorldDb"]));

            services.AddIdentity<IdentityUser, IdentityRole>().AddEntityFrameworkStores<ApplicationDbContext>();
            services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme).AddJwtBearer(config =>{
                config.RequireHttpsMetadata=false;
                config.SaveToken = true;
                config.TokenValidationParameters = new TokenValidationParameters
                {
                    ValidateIssuerSigningKey = true,
                    IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["Secret"])),
                    ValidateIssuer = false,
                    ValidateAudience = false
                };
            });
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            app.UseAuthentication();
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseCors(builder => builder
                   .AllowAnyOrigin()
                   .AllowAnyMethod()
                   .AllowAnyHeader());

            app.UseHttpsRedirection();

            app.UseRouting();

            app.UseAuthorization();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
            });
        }
    }
...