Я создал контекст (с помощью скаффолдинга), а также пользователя.Я также установил играть в БД (и создал миграцию).Это работает отлично!Теперь я просто хотел бы создать роль и затем назначить ее пользователю.
Для этого я изменил свой файл startup.cs, чтобы продолжить (я не смог найти учебник, который показывает, каксоздать / назначить роль с контекстом, отличным от контекста ApplicationDbContext).
Я доволен ошибкой в моем коде (по крайней мере, мне так кажется), но я не знаю, как с этим справиться и что делатьзамените объект.
Итак, я создал метод CreateRoles, который получает serviceProvider (типа IServiceProvider), и в этом методе я пытаюсь инициализировать Рим, а затем назначить его другим пользователям моей базы данных.
Моя проблема здесь (я думаю):
var RoleManager = serviceProvider.GetRequiredService> ();
Действительно, я думаю, что используется для ApplicationDbContext, кромечто я использую jakformulaireContext.
Мой вопрос: что мне заменить (если это то, что мне нужно заменить)?
Дайте мне знать, если вам нужна информация о режиме или код режима!
Класс запуска
открытый класс Startup {public Startup (конфигурация IConfiguration) {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.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.AddDbContext<jakformulaireContext>(options =>
options.UseSqlServer(
Configuration.GetConnectionString("jakformulaireContextConnection")));
services.AddDefaultIdentity<jakformulaireUser>(configg =>
{
configg.SignIn.RequireConfirmedEmail = true;
}).AddEntityFrameworkStores<jakformulaireContext>(); ;
var config = new AutoMapper.MapperConfiguration(cfg =>
{
cfg.AddProfile(new MappingProfile());
});
var mapper = config.CreateMapper();
services.AddSingleton(mapper);
//services.AddAutoMapper();
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
services.AddDistributedMemoryCache();
services.AddSession();
// requires
// using Microsoft.AspNetCore.Identity.UI.Services;
// using WebPWrecover.Services;
services.AddSingleton<IEmailSender, EmailSender>();
services.Configure<AuthMessageSenderOptions>(Configuration);
services.AddCors(options =>
{
options.AddPolicy("CorsPolicy",
builder => builder.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
});
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env, IServiceProvider serviceProvider)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
app.UseDatabaseErrorPage();
}
else
{
app.UseExceptionHandler("/Home/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseCookiePolicy();
app.UseSession();
app.UseAuthentication();
app.UseCors("CorsPolicy");
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
//CreateRoles(serviceProvider).Wait();
}
private async Task CreateRoles(IServiceProvider serviceProvider)
{
//initializing custom roles
var RoleManager = serviceProvider.GetRequiredService<RoleManager<IdentityRole>>();
var UserManager = serviceProvider.GetRequiredService<UserManager<jakformulaireUser>>();
string[] roleNames = { "Guest", "Member", "Admin" };
IdentityResult roleResult;
foreach (var roleName in roleNames)
{
var roleExist = await RoleManager.RoleExistsAsync(roleName);
if (!roleExist)
{
//create the roles and seed them to the database: Question 1
roleResult = await RoleManager.CreateAsync(new IdentityRole(roleName));
}
}
jakformulaireUser user = await UserManager.FindByEmailAsync("test@test.com");
if (user == null)
{
user = new jakformulaireUser()
{
UserName = "test@test.com",
Email = "test@test.com",
EmailConfirmed = true
};
await UserManager.CreateAsync(user, "Test123$");
}
await UserManager.AddToRoleAsync(user, "Member");
jakformulaireUser user1 = await UserManager.FindByEmailAsync("test@live.be");
if (user1 == null)
{
user1 = new jakformulaireUser()
{
UserName = "test@live.be",
Email = "test@live.be",
EmailConfirmed = true
};
await UserManager.CreateAsync(user1, "Test123$");
}
await UserManager.AddToRoleAsync(user1, "Admin");
}
}
Context
public class jakformulaireContext : IdentityDbContext<jakformulaireUser>
{
public jakformulaireContext(DbContextOptions<jakformulaireContext> options)
: base(options)
{
}
protected override void OnModelCreating(ModelBuilder builder)
{
base.OnModelCreating(builder);
// Customize the ASP.NET Identity model and override the defaults if needed.
// For example, you can rename the ASP.NET Identity table names and more.
// Add your customizations after calling base.OnModelCreating(builder);
}
}