ASP.Net用户名到电子邮件

时间:2013-10-20 19:30:29

标签: asp.net asp.net-mvc-5 asp.net-identity

我正在使用新的ASP.NET身份(RTM),我想知道如何将注册和登录从用户名更改为电子邮件。

我的想法是,我希望我的用户使用他们的电子邮件和密码进行注册(也可以使用外部登录获取电子邮件),并在顶部设置显示名称/用户名。

我查看了IdentityUser,我可以看到UserName在那里,但是因为它包含在ASP.Net Identity中,无法更改。

我知道我可以使用'UserName'作为电子邮件,使用自定义验证器,然后为ApplicationUser添加一个名为DisplayName的额外属性,但这更像是一个黑客攻击而不是解决方案。

我希望我的问题很明确。提前致谢。

7 个答案:

答案 0 :(得分:23)

如果你真的想用电子邮件地址登录,那么,恕我直言,你建议的“黑客”是最好的办法。因为,如果你坚持“正确地做”,你必须至少

  • 修改数据库架构,显然是
  • 自己确保用户名唯一性(您可以为数据库约束/索引执行此操作,但您必须找到一种处理错误并将其报告给用户的好方法)。
  • 找到一个很好的替代品,只需在您的代码中编写“User.Identity.UserName”
  • 可能更多

另一方面,如果您决定“破解”您需要的UserName字段

  • 修改RegisterViewModel验证(将[EmailAddress]添加到UserName属性),可能会稍微自定义[Display(Name = ...)]等。
  • 确保AccountController中使用的UserManager.UserValidator实例允许在电子邮件地址中使用特殊字符。为此,请确保其非默认构造函数如下所示:

    public AccountController(UserManager<ApplicationUser> userManager)
    {
        UserManager = userManager;
        var userValidator = UserManager.UserValidator as UserValidator<ApplicationUser>;
        userValidator.AllowOnlyAlphanumericUserNames = false;
    }
    

我希望这可以帮助您权衡两种方法的优缺点,并提出最佳解决方案。祝你好运!

答案 1 :(得分:9)

参加聚会的时间已经很晚了,但我以为我会投入0.02美元。

虽然UserNameEmail都是IdentityUser的一部分并且因此是必需的,但请注意它们都标记为virtual,这是正确的。如果您希望UserNameEmail成为电子邮件地址,请让ApplicationUser模型封装逻辑,如下所示:

public class ApplicationUser : IdentityUser
{
    private string _userNameEmailBackingField;

    public override string UserName
    {
        get { return _userNameEmailBackingField; }
        set { _userNameEmailBackingField = value; }
    }

    public override string Email
    {
        get { return _userNameEmailBackingField; }
        set { _userNameEmailBackingField = value; }
    }

    //The rest of your ApplicationUser logic
}

然后在您的视图模型中,仅公开单个属性并将其映射到ApplicationUser实例中的任一个/,确保使用[Required][EmailAddress]装饰视图模型属性属性。

正如其他人所提到的,您需要确保AllowOnlyAlphanumericUserNames false的{​​{1}}设置为UserManager,但是我你可以在VS2013中使用最新的网页模板开箱即用。

答案 2 :(得分:6)

我目前正在为Identity 1.1模板开发此功能,该模板将切换到电子邮件并添加帐户确认/忘记密码功能,我们考虑的两个选项是hack(使用用户名作为带验证的电子邮件)并添加额外的电子邮件字段,与我们倾向于的用户名分开。

可能会在1.1中向UserManager添加一些特定于电子邮件的api:

FindByEmail
SetEmail
GetEmail

答案 3 :(得分:5)

更改UserManager对象的UserValidator属性:

public class UserManager : UserManager<User>
{
    public IUserStore<User> Users { get; private set; }
    public UserManager(IUserStore<User> store) : base(store)
    {
        Users = store;
        UserValidator = new UserValidator<User>(this) {AllowOnlyAlphanumericUserNames = false};
    }
}

答案 4 :(得分:3)

正如您可能已经发现的那样(并且可以预期),2014年3月发布的ASP.NET Identity 2.0.0在框架中添加了此功能。

公告:http://blogs.msdn.com/b/webdev/archive/2014/03/20/test-announcing-rtm-of-asp-net-identity-2-0-0.aspx

完整示例和教程,包括帐户确认:http://www.asp.net/identity/overview/features-api/account-confirmation-and-password-recovery-with-aspnet-identity

答案 5 :(得分:1)

在处理类似问题时,我发现最简单的解决方案是将用户名输入标记为“电子邮件”,然后在onCreating期间手动设置会员电子邮件。

cp /var/lib/jenkins/jobs/api/workspace/target/*.jar  /home/jenkins/api

答案 6 :(得分:0)

我得到了这个。

首先转到accountViewModels并为UserName添加属性

Public Class RegisterViewModel
    <Required>
    <Display(Name:="User Name")>
    Public Property UserName As String

    <Required>
    <EmailAddress>
    <Display(Name:="Email")>
    Public Property Email As String

修改您的注册视图后添加用户名属性

<div class="form-group">
        @Html.LabelFor(Function(m) m.UserName, New With {.class = "col-md-2 control-label"})
        <div class="col-md-10">
            @Html.TextBoxFor(Function(m) m.UserName, New With {.class = "form-control"})
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(Function(m) m.Email, New With {.class = "col-md-2 control-label"})
        <div class="col-md-10">
            @Html.TextBoxFor(Function(m) m.Email, New With {.class = "form-control"})
        </div>
    </div>

完成此操作后,请修改您的登录视图

                @Html.ValidationSummary(True, "", New With {.class = "text-danger"})
            <div class="form-group">
                @Html.Label("User Name", New With {.class = "col-md-2 control-label"})
                <div class="col-md-10">
                    @Html.TextBoxFor(Function(m) m.Email, New With {.class = "form-control"})
                    @Html.ValidationMessageFor(Function(m) m.Email, "", New With {.class = "text-danger"})
                </div>
            </div>
            <div class="form-group">
                @Html.LabelFor(Function(m) m.Password, New With {.class = "col-md-2 control-label"})
                <div class="col-md-10">
                    @Html.PasswordFor(Function(m) m.Password, New With {.class = "form-control"})
                    @Html.ValidationMessageFor(Function(m) m.Password, "", New With {.class = "text-danger"})
                </div>
            </div>

这就是你所需要的一切。这样,您可以使用UserName而不是使用电子邮件地址进行登录。