首页 > 作文

PHP crypt()函数的用法讲解

更新时间:2023-04-06 15:27:52 阅读: 评论:0

php crypt() 函数

定义和用法

crypt() 函数返回使用 des、blowfish 或 md5 算法加密的字符串。

在不同的操作系统上,该函数的行为不同,某些操作系统支持一种以上的算法类型。在安装时,php 会检查什么算法可用以及使用什么算法。

确切的算法依赖于 salt 参数的格式和长度。salt 可以通过增加由一个特定字符串与一个特定的加密方法生成的字符串的数量来使得加密更安全。

这里有一些和 crypt() 函数一起使用的常量。这些常量值是在安装时由 php 设置的。

常量:

[crypt_salt_length] – 默认的加密长度。使用标准的 des 加密,长度为 2[crypt_世界十大山峰std_des] – 标准的基于 des 加密有 2 个字符的 salt,来自字母表 “./0-9a-za-z”。在 salt 中使用无效的字符将引发函数失败。[crypt_ext_des] – 扩展的基于 des 加密有 9 个字符的 salt,由 1 个下划线,后边跟 4 个字节的迭代次数和 4 个字节的 salt 组成。这些被编码为可打印字符,每个字符 6 位,最低有效字符优先。值 0 到 63 被编码为 “./0-9a-za-z”。在 salt 中使用无效的字符将引发函数失败。[crypt_md5] – md5 加密有 12 个字符的 salt,以 $1$ 开始。[crypt_blowfish] – blowfish 加密有一个以 $2a$、$2x$ 或 $2y$ 开始的 salt,一个两位数的 cost 参数 “$”,以及来自字母表 “./0-9a-za-z” 中的 22 个字符。使用字母表以外的字符将引发函数返回一个长度为 0 的字符串。”$” 参数是以 2 为底的基于 blowfish 散列算法的迭代次数的对数,必须在 04-31 范围内。在该范围以外的值将引发函数失败。[crypt_sha_256] – sha-256 加密有 16 个字符的 salt,以 $5$ 开始。如果 salt 字符串以 “rounds=$” 开始,n 的数字值用于表示散列循环被执行的次数,这与 blowfish 中的 cost 参数类似。默认的循环次数是 5000,最小值是 1000,最大值是 999,999,999。任何超出这个范围的 n 的值将会转换成最接近的边界值。[crypt_sha_512] – sha-512 加密有 16 个字符的 salt,以 $6$ 开始。 如果 salt 字符串以 “rounds=$” 开始,n 的数字值用于表示散列循环被执行的次数,这与 blowfish 中的 cost 参数类似。默认的循环次数是 5000,最小值是 1000,最大值是 999,999,999。任何超出这个范围的 n 的值将会转换成最接近的边界值。

在该函数支持多种算法的系统上,上面的常量如果支持则设置为 “1”,否则设置为 “0”。

注释: 没有相应的解密函数。crypt() 函数使用一种单向算法。

语法

crypt( _str,salt_ )

实例 1洛克王国幻象勇士

<?php $hashed_password = crypt('mypassword'); // 自动生成盐值 /* 你应当使用 crypt()得到的完整结果作为盐值进行密码校验,以此来避免使用不同散列算法导致关于志向的议论文的问题。(如上所述,基于标准 des 算法的密码散列使用 2 字符盐值,但是基于 md5算法的散列使用 12 个字符盐值。)*/ if (hash_equals($hashed_password, crypt($ur_input,$hashed_password))) { echo "password verified!"; } ?>

实例 2

利用 htpasswd 进行 crypt() 加密:

<?php // 设置密码 $password = 'mypassword'; // 获取散列值,使用自动盐值 $hash =crypt($passwor很好的句子d); ?>

实例 1

在本实例中,我们以不同散列类型使用:

<?php if (crypt_std_des == 1) { echo 'standard des: ' . crypt('rasmuslerdorf','rl') . "\n"; } if (crypt_ext_des == 1) { echo 'extended des: ' .crypt('rasmuslerdorf', '_j9..rasm') . "\n"; } if (crypt_md5 == 1) { echo 'md5:' . crypt('rasmuslerdorf', '解放军信息工程大学$1$rasmusle$') . "\n"; } if (crypt_blowfish == 1){ echo 'blowfish: ' . crypt('rasmuslerdorf','$2a$07$usomesillystringforsalt$') . "\n"; } if (crypt_sha256 == 1) { echo'sha-256: ' . crypt('rasmuslerdorf','$5$rounds=5000$usomesillystringforsalt$') . "\n"; } if (crypt_sha512 == 1){ echo 'sha-512: ' . crypt('rasmuslerdorf','$6$rounds=5000$usomesillystringforsalt$') . "\n"; } ?>

上面的代码输出如下(取决于操作系统):

standard des: rl.3stkt.4t8m
extended des: _j9..rasmbyk8r9aiwnc
md5: $1$rasmusle$riscgzzpwk3uhdidwxvin0
blowfish: $2a$07$usomesillystringfore2udlvp1ii2e./u9c8sbjqp8i90dh6hi
sha-256: $5$rounds=5000$usomesillystri$kqjwpanxzhkq2bob43tsayhewsq1lr5qnypcdh/tp.6
sha-512: $6$rounds=5000$usomesillystri$d4irlxatmp7rx3p3inaxbeoomnaihckrvqp22jz6ey47wc6bkroiuuuboov1i.s5kpgertp/en5mco.chwqw21

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对www.887551.com的支持。如果你想了解更多相关内容请查看下面相关链接

本文发布于:2023-04-06 15:27:51,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/aa878f1c1558fbc7f6484f1e45a53921.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:PHP crypt()函数的用法讲解.doc

本文 PDF 下载地址:PHP crypt()函数的用法讲解.pdf

标签:字符   算法   函数   字符串
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图