Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/asp.net-mvc/16.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# MVC标识,启用用户名,但登录中断_C#_Asp.net Mvc_Asp.net Identity - Fatal编程技术网

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);
    }
}