首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >替代mhash_keygen_s2k()

替代mhash_keygen_s2k()
EN

Stack Overflow用户
提问于 2012-10-09 17:38:16
回答 1查看 549关注 0票数 1

manual page说:

建议使用mhash 函数从string.创建密钥。

但是mhash手册上说:

注意:这个扩展被Hash淘汰了。

然而,我所能找到的最接近于非常有用的mhash_keygen_s2k()函数是hash_pbkdf2()函数。但是,我甚至不确定它是否适合这个工作,因为它只存在于SVN中。

所以,我是否可以依赖mhash扩展,或者它最终会被废弃和删除?如果是的话,是否有任何替代的内置函数,或者我必须自己实现盐渍S2K算法?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-09 20:57:40

最后,我偷看了m散列源代码,将其移植到PHP:

代码语言:javascript
复制
function keygen_s2k($hash, $password, $salt, $bytes)
{
    $result = false;

    if (extension_loaded('hash') === true)
    {
        foreach (range(0, ceil($bytes / strlen(hash($hash, null, true))) - 1) as $i)
        {
            $result .= hash($hash, str_repeat("\0", $i) . str_pad(substr($salt, 0, 8), 8, "\0", STR_PAD_RIGHT) . $password, true);
        }

        $result = substr($result, 0, intval($bytes));
    }

    return $result;
}

如果有人知道任何可供选择的内置功能,我还是想听听。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12805393

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档