C# MVC标识,启用用户名,但登录中断
我希望用户将他们的名字添加到应用程序中(我成功地存储了它),并使用他们的电子邮件登录。但当登录时,我得到“无效登录尝试”,我不知道为什么 在模型(C# MVC标识,启用用户名,但登录中断,c#,asp.net-mvc,asp.net-identity,C#,Asp.net Mvc,Asp.net Identity,我希望用户将他们的名字添加到应用程序中(我成功地存储了它),并使用他们的电子邮件登录。但当登录时,我得到“无效登录尝试”,我不知道为什么 在模型(AccountViewModel)中,我添加了名称: [Required] public string Name { get; set; } 在AccountController中,我做了以下更改以存储注册时的值 var user = new ApplicationUser { UserName = model.Name, Email
AccountViewModel
)中,我添加了名称:
[Required]
public string Name { get; set; }
在AccountController
中,我做了以下更改以存储注册时的值
var user = new ApplicationUser {
UserName = model.Name,
Email = model.Email
};
并且在Register.cshtml
中添加了一个字段来存储他们的名字
<div class="form-group">
@Html.LabelFor(m => m.Name, new { @class = "col-md-2 control-label" })
<div class="col-md-10">
@Html.TextBoxFor(m => m.Name, new { @class = "form-control" })
</div>
</div>
您用作模型名的用户名是用于身份验证的用户名,而不是电子邮件。在这种情况下,您可能需要创建一个新字段来存储您的姓名。
PasswordSignInAsync
检查用户名和密码。看起来它不起作用仅仅是因为你通过电子邮件
就可以了,但是用户名
字段似乎是多余的。。。我的意思是它是有效的,但是……如果你使用电子邮件作为用户名,会有重复,但是如果你想将它们分开,使用不同类型的用户名,并且你仍然想存储电子邮件,你仍然可以这样做。谢谢你,这正是我想要的!
// POST: /Account/Login
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Login(LoginViewModel model, string returnUrl)
{
if (!ModelState.IsValid)
{
return View(model);
}
// This doesn't count login failures towards account lockout
// To enable password failures to trigger account lockout, change to shouldLockout: true
var result = await SignInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, shouldLockout: false);
switch (result)
{
case SignInStatus.Success:
return RedirectToLocal(returnUrl);
case SignInStatus.LockedOut:
return View("Lockout");
case SignInStatus.RequiresVerification:
return RedirectToAction("SendCode", new { ReturnUrl = returnUrl, RememberMe = model.RememberMe });
case SignInStatus.Failure:
default:
ModelState.AddModelError("", "Invalid login attempt.");
return View(model);
}
}