c# – 通过使用asp net identity 2.1发送重置帐户链接来重置用户
发布时间:2020-12-15 19:40:11 所属栏目:百科 来源:网络整理
导读:我有一个ASP MVC项目,我想在用户锁定后向用户的电子邮件发送解锁帐户锁定链接.我在我的项目中使用asp net identity 2.1.我可能做的是使用asp身份锁定帐户30分钟.在此时间之后,帐户将被解锁.我试图向包含重置链接的用户发送电子邮件.该链接调用具有以下代码的
我有一个ASP MVC项目,我想在用户锁定后向用户的电子邮件发送解锁帐户锁定链接.我在我的项目中使用asp net identity 2.1.我可能做的是使用asp身份锁定帐户30分钟.在此时间之后,帐户将被解锁.我试图向包含重置链接的用户发送电子邮件.该链接调用具有以下代码的方法.
[AllowAnonymous] public async Task<ActionResult> UnlockAccount(string userId) { await UserManager.ResetAccessFailedCountAsync(userId); return RedirectToAction("Login"); } 但在此之后,我的帐户仍被锁定30分钟的时间段,我在IdentityConfig.cs中设置.这在asp网络身份中是否可行. 解决方法
我知道这已经过时但是值得回答,因为我一直在想自己……
AccessFailedCount无关紧要 – 锁定用户的唯一因素是LockoutEndDateUtc.如果当前UTC日期时间在LockoutEndDateUtc之前,那么您将无法获得条目. 虽然重置很简单: await UserManager.SetLockoutEndDateAsync(userId,new DateTimeOffset(DateTime.UtcNow)); 您可以将DateTimeOffset设置为您想要的任何内容,只要它在当前DateTimeUTC之前,在我的示例中我使用DateTime.UtcNow,因为它提供了知道帐户何时解锁的额外好处. 当用户最终再次登录时,AccessFailedCount将重置为0,因此您无需担心重置该问题. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |