私はカスタムasp.netアイデンティティをやってtables.I作り付けのasp.netを使用していないが正常にカスタムCreateAsync
asp.netのIDのUpdateAsyncメソッドのカスタム実装を与える方法は?
を実装して、ユーザーを作成している今、私は新しい暗号化されたパスワードでユーザーを更新したいので、私はどのようになっておりませんUpdateAsync method
のカスタム実装を提供します。
これは私のテーブルです:
ユーザー:Id,Name,EmailId,Password,Statistics,Salary
モデル:
public class UserModel : IUser
{
public string Id { get; set; }
public string Name { get; set; }
public string EmailId { get; set; }
public string Password { get; set; }
public int Salary { get; set; }
}
IUserstoreを実装マイカスタムクラス:
public class UserStore : IUserStore<UserModel>, IUserPasswordStore<UserModel>
{
private readonly MyEntities _dbContext;
private readonly HttpContext _httpContext;
// How to implement this method for updating only user password
public Task UpdateAsync(UserModel user)
{
throw new NotImplementedException();
}
public Task CreateAsync(UserModel user)
{
return Task.Factory.StartNew(() =>
{
HttpContext.Current = _httpContext ?? HttpContext.Current;
var user = _dbContext.User.Create();
user.Name = user.Name;
user.EmailId = user.EmailId;
user.EmailAddress = user.Email;
user.Password = user.Password;
_dbContext.Users.Add(dbUser);
_dbContext.SaveChanges();
});
}
public Task SetPasswordHashAsync(UserModel user, string passwordHash)
{
return Task.Factory.StartNew(() =>
{
HttpContext.Current = _httpContext ?? HttpContext.Current;
var userObj = GetUserObj(user);
if (userObj != null)
{
userObj.Password = passwordHash;
_dbContext.SaveChanges();
}
else
user.Password = passwordHash;
});
}
public Task<string> GetPasswordHashAsync(UserModel user)
{
//other code
}
}
コントローラー:
public class MyController : ParentController
{
public MyController()
: this(new UserManager<UserModel>(new UserStore(new MyEntities())))
{
}
public UserManager<UserModel> UserManager { get; private set; }
[HttpPost]
public async Task<JsonResult> SaveUser(UserModel userModel)
{
IdentityResult result = null;
if (userModel.Id > 0) //want to update user with new encrypted password
result = await UserManager.UpdateAsync(user);
else
result = await UserManager.CreateAsync(userModel.EmailId, userModel.Password);
}
}
'Task.Factory.StartNew'を使ってメソッドをバックグラウンドスレッドにプッシュするのは悪い考えです。メソッドを 'async'とマークし、' await _dbContext.SaveChangesAsync(); 'を使うか、メソッドを同期させて最後に' Task.FromResult(true); 'を返します。 –
@richardみなさん、とても良い提案をいただきありがとうございます。私は本当に感謝しています。私はこのコードをデバッグするときのように問題に直面しているし、戻って戻ってくることはありません。このtask.factory.newのためにですか? –
おそらく。また、そうでない場合でも、 'Task.Factory.StartNew'を削除すると、エラーをより簡単に見ることができます。 –