4

我必须将我的后端从 php 迁移到节点。我们使用 php crypt(使用默认随机盐)对密码进行哈希处理。例如,对于密码“d1692fab28b8a56527ae329b3d121c52”,我的基础中有以下加密密码(取决于我使用的是 md5 还是 sha512,正如 $i$ 指定的那样):

$1$7JxJYjJK$oFtCGyVvflspPtxB7YrWP.
$6$CVx6KL5l$wzk3YXlqUaz42Kb9r2lmEJhx/FBUXPRoLWN.20/XMBbgQrhp3vSHkEDF3bJEtpM3M96VZ.AMKatLGSKYZZKNH/

在 php 中,我可以使用 crypt 验证它们:

echo crypt('d1692fab28b8a56527ae329b3d121c52', '$1$7JxJYjJK$oFtCGyVvflspPtxB7YrWP.');
echo "\n";
echo crypt('d1692fab28b8a56527ae329b3d121c52', '$6$CVx6KL5l$wzk3YXlqUaz42Kb9r2lmEJhx/FBUXPRoLWN.20/XMBbgQrhp3vSHkEDF3bJEtpM3M96VZ.AMKatLGSKYZZKNH/');
echo "\n";

它返回正确的加密密码。

我没有设法通过任何节点功能获得这样的结果。我尝试了类似的东西:

require("crypto").createHmac("md5", "7JxJYjJK").update("d1692fab28b8a56527ae329b3d121c52").digest("base64");

还有许多其他人,但没有任何成功。有人可以帮我这样做吗?我绝对需要 MD5 版本 ($1$) ;sha512 会有点好(我知道这很可怕,但它是在 prod 服务器上使用的 md5 版本,以及在测试服务器上使用的 sha512 ......)。

4

1 回答 1

1

我刚刚为我的一个项目将原始的 crypt_md5()(在 PHP 中使用)转换为 JavaScript。你可以在这里找到它:

https://github.com/BlaM/cryptMD5-for-javascript

(仅支持 1 美元,但这至少是您正在寻找的一部分。)

于 2013-10-24T15:58:38.317 回答