C#Identity UserManager CreateAsync然后FindByEmailAsync返回Id = 0的用户

时间:2015-06-11 00:39:05

标签: dapper sqlconnection asp.net-identity-2 dapper-extensions

与Dapper的身份。

我的身份中的用户属于IUser< int>

当用户注册时,我在AccountController中创建了一个用户:

注册POST:

if (ModelState.IsValid)
{
    user = new MySiteUserRecord
    {
        UserName = model.UserName,
        AccessFailedCount = 0,
        ApplicationName = "Portal",
        Description = string.Empty,
        PhoneNumber = model.PhoneNumber ?? string.Empty,
        Email = model.Email
    };
    var result = await UserManager.CreateAsync(user, model.Password);
    if (result.Succeeded)
    {
       ...

如果成功,我需要获取新创建的用户记录,因为上面的“新”用户类不知道它的ID是什么......

       user = await UserManager.FindByNameAsync(model.UserName);

当我查看此找到的用户记录时,user.Id = 0。 但是如果我查看数据库,这个新创建的用户的行就是下一个Id,例如9 即使我执行直接Db查询,而不是使用UserManager的FindByNameAsync函数,返回的Id始终为0.

我真的很难过 - 我可能错过了一些东西......

如何通过分配的数据库ID获取用户记录?

编辑:我的查找用户功能是:

    Task<MySiteUserRecord> IUserStore<MySiteUserRecord, int>.FindByNameAsync(string userName)
    {
        var predicate = Predicates.Field<MySiteUserRecord>(f => f.UserName, Operator.Eq, userName);
        return Task.Factory.StartNew(() => _sqlConn.GetList<MySiteUserRecord>(predicate).FirstOrDefault());
    }

1 个答案:

答案 0 :(得分:0)

我的用户类的映射器类专门告诉DapperExtensions忽略我的ID字段。使用其他Dapper扩展时必须要小心,并且需要研究它们如何与您的系统交互。