0

我只是想知道如何检查(当用户在密码过期后更改密码时)如何使用(在 WebMatrix 中)if 分支来确保新密码不等于以前的密码。

除了上次使用的密码之外,我认为我不想再检查任何密码历史记录,所以只要我可以检查以前的密码,我认为就可以了。

我当然可以查询数据库并检查,但由于密码不是以纯文本形式存储的,我知道这不起作用,但我也在这里检查了 WebSecurity 方法:

http://msdn.microsoft.com/en-us/library/webmatrix.webdata.websecurity(v=vs.111).aspx

并没有找到任何东西。

完成这项工作的最佳方法是什么?

4

3 回答 3

1

由于密码未存储在数据库中,因此您无法执行此操作,除非您在用户首次注册时以及随后更改密码时记下密码。

具有讽刺意味的是,通过存储原始密码(即使处于加密状态),您实际上会降低应用程序的安全性。

于 2012-10-29T16:17:15.033 回答
1

对于任何感兴趣的人,我确实找到了一个很好的解决这个问题的方法,可以很好地完成工作。

但是请记住,这仅适用于检查他们拥有/拥有的最后一个密码。

这是我实现的:

首先,当然,在登录页面中,在其他代码中以及在实际登录后,我有明显的(检查他们的密码是否超过 6 个月并且需要更改):

if(WebSecurity.GetPasswordChangedDate(username).AddMonths(6) < DateTime.UtcNow)
{
    WebSecurity.Logout();
    Session["gActionMessage"] = "Your password has expired. Please change your password by visiting \"Login\" then \"Change Password\"";
    Session["gActionMessageDisplayed"] = "not";
    Response.Redirect("~/");
}

然后,我在“更改密码”页面上想到了这个(实际上是密码重置令牌的电子邮件验证后的重定向页面,但你明白了):

if(WebSecurity.Login(email, newPassword, false) && WebSecurity.UserExists(email) && WebSecurity.GetPasswordChangedDate(email).AddMonths(6) < DateTime.UtcNow)
{
    WebSecurity.Logout();
    errorMessage = "You cannot repeat your last expired password.";
}

这里的 if 分支进行三项检查:

首先,如果可能的话,它会根据他们输入的新密码有效地检查和登录他们。

其次,它检查用户是否存在(不确定我是否需要这个,但无论如何)。

最后,检查以确保他们的密码更改日期超过 6 个月(因为同一页面用于“忘记密码”的内容,所以这只是确保在以这种方式出错之前满足正确的情况)。

因此,简而言之,如果他们的新密码仍然足以让他们登录(当然是在实际更改之前),那么这是重复的,随后将他们注销并向他们抛出错误消息,而不是更改密码。如果登录还不够,则不能是重复密码,(只要满足其他要求)然后更改密码。

希望这对将来可能需要在更改密码时使用 WebMatrix 的非重复密码的任何人有所帮助!

于 2012-10-29T18:23:41.037 回答
0

引用 System.Web.Helpers 程序集,

创建一个名为“UserPasswordHistory”的自定义表,其中包含存储在“Password”列中的散列密码,并在“PasswordVersion”列中增加版本号,每次注册用户或更新给定密码时都会插入一行用户,以下代码有效。

var userProfile = db.UserProfiles.First(x => x.UserId == userId);
                var passwords = (userProfile.UserPasswordHistory
                                          .OrderByDescending(x => x.PasswordVersion)
                                          .Take(_configuration.PasswordCountBeforeReuseAllowed))
                                          .Select(x => x.Password);

return passwords.Any(previousPassword => Crypto.VerifyHashedPassword(previousPassword, password));

要回答专门提出的问题 _configuration.PasswordCountBeforeReuseAllowed 将设置为 1

于 2015-11-13T15:13:04.217 回答