提问人:Goga Gate 提问时间:11/7/2023 最后编辑:dropoutcoderGoga Gate 更新时间:11/7/2023 访问量:59
在身份实现中面临多个错误
Facing multiple errors on identity implementation
问:
我正在尝试在我的 Web 应用程序中实现该标识。我添加了从 IdentityUser 基类继承的自定义用户。对于角色,我使用基 IdentityRole 类。我还有 DbInitializer 来提供一些种子数据,以防数据库中不存在它。 项目:ASP.NET Core Web APP(Model-View-Controller) .NET 版本:6.NET version: 6
相应的代码片段:
AppDbConetxt
public class AppDbContext : IdentityDbContext<ApplicationUser>
{
public DbSet<Actor> Actors { get; set; }
public DbSet<Cinema> Cinemas { get; set; }
public DbSet<Movie> Movies { get; set; }
public DbSet<Producer> Producers { get; set; }
//Order related tables
public DbSet<Order> Orders { get; set; }
public DbSet<OrderItem> OrderItems { get; set; }
public DbSet<ShoppingCartItem> ShoppingCartItems { get; set; }
public AppDbContext(DbContextOptions<AppDbContext> options) : base(options) { }
}
应用用户
public class ApplicationUser : IdentityUser
{
[Display(Name = "Full name")]
public string FullName { get; set; } //This is the additional property which does not come from the IdentityUser class.
}
程序 .cs(不提供库))
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllersWithViews();
//Adding DbContext configurations
builder.Services.AddDbContext<AppDbContext>(options =>
{
//In order to use SQL Server we need to add a new NuGet package Microsoft.EntityFrameworkCore.SqlServer
options.UseSqlServer(builder.Configuration.GetConnectionString("eTicketsConnection"));
});
//Service Registration
builder.Services.AddScoped<IActorsService, ActorsService>();
builder.Services.AddScoped<IProducersService, ProducersService>();
builder.Services.AddScoped<ICinemasService, CinemaService>();
builder.Services.AddScoped<IMoviesService, MoviesService>();
builder.Services.AddScoped<IOrdersService, OrdersService>();
builder.Services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();
builder.Services.AddScoped(sc => ShoppingCart.GetShoppingCart(sc));
builder.Services.AddIdentity<ApplicationUser, IdentityRole>().AddEntityFrameworkStores<AppDbContext>();
builder.Services.AddAuthentication(options =>
{
options.DefaultScheme = CookieAuthenticationDefaults.AuthenticationScheme;
});
builder.Services.AddMemoryCache();
builder.Services.AddSession();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
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.UseRouting();
app.UseSession();
//Authentication & Authrorization
app.UseAuthentication();
app.UseAuthorization();
app.MapControllerRoute(
name: "default",
pattern: "{controller=Home}/{action=Index}/{id?}");
//Seed Data
AppDbInitializer.Seed(app);
//Seed User and Roles
AppDbInitializer.SeedUsersAndRoles(app).Wait();
app.Run();
AppDbInitializer
public class AppDbInitializer
{
public static async Task SeedUsersAndRoles(IApplicationBuilder applicationBuilder)
{
using (IServiceScope serviceScope = applicationBuilder.ApplicationServices.CreateScope())
{
RoleManager<IdentityRole> roleManager = serviceScope.ServiceProvider.GetRequiredService<RoleManager<IdentityRole>>();
if (!await roleManager.RoleExistsAsync(UserRoles.Admin))
await roleManager.CreateAsync(new IdentityRole(UserRoles.Admin));
if(!await roleManager.RoleExistsAsync(UserRoles.User))
await roleManager.CreateAsync(new IdentityRole(UserRoles.User));
UserManager<ApplicationUser> userManager = serviceScope.ServiceProvider.GetRequiredService<UserManager<ApplicationUser>>();
string adminUserEmail = "[email protected]";
ApplicationUser adminUser = await userManager.FindByEmailAsync(adminUserEmail);
if(adminUser == null)
{
ApplicationUser newAdminUser = new ApplicationUser()
{
FullName = "Admin User",
UserName = "admin-user",
Email = adminUserEmail,
EmailConfirmed = true
};
await userManager.CreateAsync(newAdminUser, "Coding123"); //Adding to the database
await userManager.AddToRoleAsync(newAdminUser, UserRoles.Admin); //Checks if the user exists in the database and adds the role.
}
string appUserEmail = "[email protected]";
ApplicationUser appUser = await userManager.FindByEmailAsync(appUserEmail);
if (appUser == null)
{
ApplicationUser newAppuser = new ApplicationUser()
{
FullName = "Application User",
UserName = "app-user",
Email = adminUserEmail,
EmailConfirmed = true
};
await userManager.CreateAsync(newAppuser, "Coding123"); //Adding to the database
await userManager.AddToRoleAsync(newAppuser, UserRoles.User); //Checks if the user exists in the database and adds the role.
}
}
}
}
这是错误消息
我试图解释我在 ASP.NET Core MVC 中的身份实现方面面临的问题。期望获得如何处理问题的解决方案。
答:
1赞
Terentiy Gatsukov
11/7/2023
#1
在 your for the app 用户中,您可能会错误地使用 .这将创建两个具有相同电子邮件地址的用户,如果您尝试通过电子邮件检索他们,这可能会导致一个用户,因为每个电子邮件地址只有一个用户。AppDbInitializer
adminUserEmail
appUserEmail
InvalidOperationException
FindByEmailAsync
string adminUserEmail = "[email protected]";
// ...
string appUserEmail = "[email protected]";
// ...
ApplicationUser newAppuser = new ApplicationUser()
{
FullName = "Application User",
UserName = "app-user",
Email = adminUserEmail, // <-- Maybe it is a copy-paste error. Maybe use it appUserEmail instead adminUserEmail.
EmailConfirmed = true
};
评论
0赞
Goga Gate
11/7/2023
谢谢你的提示。我已经更改了它,但仍然有相同的错误。我的 AppDbInitializer 类中的 SeedUsersAndRoles 方法肯定有问题。
0赞
Terentiy Gatsukov
11/7/2023
你能提供堆栈跟踪吗?@user22868831
0赞
Goga Gate
11/7/2023
对不起,但我不知道那是什么:|我稍后会检查它,如果可以的话提供。感谢您的帮助。欣赏!
0赞
Goga Gate
11/7/2023
错误发生在 AppDbInitializer 类中,行为:ApplicationUser adminUser = await userManager.FindByEmailAsync(adminUserEmail);这可能是因为 NuGet 包版本而发生的吗?除了Microsoft.AspNetCore.Identity.EntityFrameworkCore之外,我所有的包都是7.0.9。我无法更新标识包,因为我收到错误,指出 Microsoft.AspNetCore.Identity.EntityFramework 7.0.9 与 不兼容。KE16型
评论