繁体   English   中英

为什么我不能用新播种的超级用户(Asp.Net Core Identity)登录?

[英]Why can't I log in with the newly seeded power user (Asp.Net Core Identity)?

我有一个带有身份的 Asp.Net Core 3.1 web 应用程序。 我使用此代码将高级用户播种到数据库:

var poweruser = new ApplicationUser
{
    UserName = Configuration.GetSection("AppSettings")["UserName"],
    Email = Configuration.GetSection("AppSettings")["UserEmail"],
    FirstName = Configuration.GetSection("AppSettings")["UserFirstName"],
    LastName = Configuration.GetSection("AppSettings")["UserLastName"],
    PhoneNumber = Configuration.GetSection("AppSettings")["UserPhoneNumber"]
};

string userPassword = Configuration.GetSection("AppSettings")["UserPassword"];
var user = await UserManager.FindByEmailAsync(Configuration.GetSection("AppSettings")["UserEmail"]);

if (user == null)
{
    var createPowerUser = await UserManager.CreateAsync(poweruser, userPassword);
    if (createPowerUser.Succeeded)
    {
        await UserManager.AddToRoleAsync(poweruser, "SiteAdmin");
    }
}

appsettings.json中,“AppSettings”部分如下所示:

"AppSettings": {
  "UserName": "ab@cd.ef",
  "UserEmail": "ab@cd.ef",
  "UserFirstName": "Admin",
  "UserLastName": "Admin",
  "UserPhoneNumber":  "12345678",
  "UserPassword": "pa5sw&Rd"
}

用户在数据库中创建:

在此处输入图像描述

但是当我尝试登录时,登录尝试失败。 我看过这个这个类似的帖子,但在这些情况下,用户名和 email 地址并不相同。 就我而言,它们是(ab@cd.ef)。 我从 appsettings.json 复制粘贴了密码,以确保我没有输入错误。

更新

这是接收登录表单(Login.cshtml.cs)的方法:

public async Task<IActionResult> OnPostAsync(string returnUrl = null)
{
    returnUrl = returnUrl ?? Url.Content("~/");

    if (ModelState.IsValid)
    {
        // This doesn't count login failures towards account lockout
        // To enable password failures to trigger account lockout, set lockoutOnFailure: true
        var result = await _signInManager.PasswordSignInAsync(Input.Email, Input.Password, Input.RememberMe, lockoutOnFailure: false);
        if (result.Succeeded)
        {
            _logger.LogInformation("User logged in.");
            return LocalRedirect(returnUrl);
        }
        if (result.RequiresTwoFactor)
        {
            return RedirectToPage("./LoginWith2fa", new { ReturnUrl = returnUrl, RememberMe = Input.RememberMe });
        }
        if (result.IsLockedOut)
        {
            _logger.LogWarning("User account locked out.");
            return RedirectToPage("./Lockout");
        }
        else
        {
            ModelState.AddModelError(string.Empty, "Invalid login attempt.");
            return Page();
        }
    }

    // If we got this far, something failed, redisplay form
    return Page();
}

当一个难题的解决方法变得很简单时,你不讨厌它吗?

在这种情况下,只需将PhoneNumberConfirmed设置为true ,我就可以登录了......

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM