How to setup password expiration using ASP.NET Identity Framework(如何使用 ASP.NET Identity Framework 设置密码过期)
问题描述
我有一个使用 Identity 的 ASP.NET 项目.对于有关密码的身份配置,正在使用 PasswordValidator
.如何在 PasswordValidator
当前(RequiredLength
、RequiredDigit
等)之外扩展密码的执行,以满足要求输入密码的要求N 天后过期?
I have a ASP.NET project using Identity. For Identity Configuration regarding passwords, the PasswordValidator
is being used. How do I expand the enforcement of password beyond what PasswordValidator
has currently (RequiredLength
, RequiredDigit
, etc.) to satisfy a requirement that asks for password expiration after N days?
推荐答案
ASP.NET Identity 2 中没有内置这样的功能.最简单的方法是在用户上添加一个字段,例如 LastPasswordChangedDate.然后在每次授权时检查这个字段.
There is no such functionality builtin ASP.NET Identity 2. Easiest is to add a field on the user like LastPasswordChangedDate. And then check this field during each Authorization.
public class ApplicationOAuthProvider : OAuthAuthorizationServerProvider
{
public override async Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
{
var user = await GetUser(context.UserName, context.Password);
if(user.LastPasswordChangedDate.AddDays(20) < DateTime.Now)
// user needs to change password
}
}
这篇关于如何使用 ASP.NET Identity Framework 设置密码过期的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何使用 ASP.NET Identity Framework 设置密码过期
- 在哪里可以找到使用中的C#/XML文档注释的好例子? 2022-01-01
- Web Api 中的 Swagger .netcore 3.1,使用 swagger UI 设置日期时间格式 2022-01-01
- 良好实践:如何重用 .csproj 和 .sln 文件来为 CI 创建 2022-01-01
- 带有服务/守护程序应用程序的 Microsoft Graph CSharp SDK 和 OneDrive for Business - 配额方面返回 null 2022-01-01
- WebMatrix WebSecurity PasswordSalt 2022-01-01
- MoreLinq maxBy vs LINQ max + where 2022-01-01
- C#MongoDB使用Builders查找派生对象 2022-09-04
- 如何用自己压缩一个 IEnumerable 2022-01-01
- 输入按键事件处理程序 2022-01-01
- C# 中多线程网络服务器的模式 2022-01-01