内容简介:最后谈一谈安全保护口令的的标准算法,这就是 bcrypt 算法。为了把事情说清楚,分两篇文章描述:本文主要理解 bcrypt 算法,bcrypt 算法可以认为是 KDF 函数的一种实现,也有迭代因子的概念。bcrypt 算法基于 Blowfish 块密钥算法,bcrypt 算法已经有10多年的历史,而 Blowfish 密钥算法更是有20多年的历史,久经考验,所以被认为是 Hash 加密口令的标准算法。
最后谈一谈安全保护口令的的标准算法,这就是 bcrypt 算法。为了把事情说清楚,分两篇文章描述:
-
说说 bcrypt 算法,以及通过 PHP 的crypt()算法进一步参数阐述,虽然crypt()算法已经不推荐使用了,但对于理解 bcrypt 算法还是非常好的,可以看看它的历史。
-
在一个系统中,如果有多种开发语言,那么 bcrypt 算法是否通用呢?通过 PHP 和 Ptyhon 语言进行描述。
本文主要理解 bcrypt 算法,bcrypt 算法可以认为是 KDF 函数的一种实现,也有迭代因子的概念。
bcrypt 算法基于 Blowfish 块密钥算法,bcrypt 算法已经有10多年的历史,而 Blowfish 密钥算法更是有20多年的历史,久经考验,所以被认为是 Hash 加密口令的标准算法。
bcrypt 算法在内部会使用内存初始化 hash 过程,由于需要内存,虽然在 CPU 上运行很快,但在 GPU 并行运算却不快,这也减缓了攻击者的破解速度。
接下去我使用 PHP 语言中的 crypt() 函数介绍如何使用 bcrypt 算法,如果你对 Hash 保护口令了解的不多,那么使用 crypt() 函数可能会存在很多问题。
首先必须明确 crypt() 函数并不是 bcrypt 算法,它可以基于 多种不同的 Hash 算法 。
该函数的原型:
string crypt ( string $str [, string $salt ] )
看上去很简单,但隐藏了很多内容。
如果你仅仅调用 crypt(),会根据操作系统版本和 PHP 版本使用相应的 Hash 算法,而且如果不显示的输入 salt,可能会得到一个弱 salt,所以不推荐这样调用 crypt() 函数,因为 屏蔽 了很多细节。
那么如何选定 bcrypt 算法(Blowfish)、迭代因子、salt,先看一个例子:
if (CRYPT_BLOWFISH == 1) { echo 'Blowfish:' . crypt('abcde', '$2a$07$woshiyigesaltzhi') . "\n"; }
-
表示使用 bcrypt 算法(注意:如果是 PHP 5.3.7 后续版本,使用 ,修复了安全风险)。
-
07 表示迭代次数为 7 次。
-
最后一个 $ 后面内容为 salt 值。
接下去看看上面代码的输出:
Blowfish:$2a$07$woshiyigesaltzhi$$$$$.lrU488y7E1Xw.JA4uizIu.PBSSe7t4y
也就是说返回值包含了 crypt() 函数相关信息,比如告诉你使用了 bcrypt 算法,迭代因子是 7,salt 是 woshiyigesaltzhi$$$$$,剩下的部分就是口令密文。
此处,遗留一个问题,crypt() 运算出来的口令密文包含 salt 是否不安全? 这会在下一篇中描述 。
crypt() 也可以使用其它的 Hash 函数,比如:
-
CRYPT_MD5:
-
CRYPT_BLOWFISH: 或
-
CRYPT_SHA256:
-
CRYPT_SHA512:
大家大概明白 crpyt() 函数的使用了,可能使用的时候有点麻烦,所以建议包装下该函数:
function better_crypt($input, $rounds = 7) { $salt = openssl_random_pseudo_bytes(22); return crypt($input, sprintf('$2a$%02d$', $rounds) . $salt); }
不管怎么说,crypt() 函数完全基于底层的 C 函数,运行环境也依赖于操作系统和PHP版本,系统和代码迁移的时候可能有多种问题,所以 PHP 从 5.5 版本以后建议使用 Password Hashing Functions ,这在下一篇会详细说一下。
最后简单提下 scrypt 算法,它是一种新的口令保护算法,是另外一种思路,被认为是口令保护的业界标准算法,但由于时间较短,现在建议还是使用 bcrypt() 算法 。
口令保护系列文章:
了解我的书 《深入浅出HTTPS:从原理的实战》 ,如果觉得还不错,还请在豆瓣上做个评论(https://book.douban.com/subject/30250772/,或点击“原文连接”)。
以上所述就是小编给大家介绍的《安全存储口令的业界标准:bcrypt 算法》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- QQ安全中心 - 动态口令的生成算法
- 请读下面的这句绕口令:ResourceManager中的Resource Estimator框架介绍与算法剖析
- “黑客”必用兵器之“密码口令破解篇”
- 使用wireshark分析ssh口令登录细节
- Python实现FTP弱口令扫描器
- 从排查端口弱口令研究打造完美防御的思路
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
代码整洁之道:程序员的职业素养
罗伯特·C.马丁 (Robert C.Martin) / 余晟、章显洲 / 人民邮电出版社 / 2016-9-1 / 49.00元
1. 汇聚编程大师40余年编程生涯的心得体会 2. 阐释软件工艺中的原理、技术、工具和实践 3. 助力专业软件开发人员具备令人敬佩的职业素养 成功的程序员在以往的工作和生活中都曾经历过大大小小的不确定性,承受过永无休止的压力。他们之所以能够成功,是因为拥有一个共同点,都深切关注创建软件所需的各项实践。他们将软件开发视为一种需要精雕细琢加以修炼的技艺,他们以专业人士的标准要求自己,......一起来看看 《代码整洁之道:程序员的职业素养》 这本书的介绍吧!