1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > php返回使用DES和Blowfish以及MD5算法加密的字符串函数crypt()

php返回使用DES和Blowfish以及MD5算法加密的字符串函数crypt()

时间:2020-12-02 03:01:40

相关推荐

php返回使用DES和Blowfish以及MD5算法加密的字符串函数crypt()

后端开发|php教程

Blowfish,php,算法

后端开发-php教程

源码 录入 打印,ubuntu终端没有光标,爬虫用什么好用,php gsmmodem,长春seo攻略lzw

定义和用法

网业发布站源码,ubuntu菜鸟入门教学,tomcat中设置日志级别,大虾爬虫子,PHP自由顾问,seo的中文意思是什么营销lzw

crypt() 函数返回使用 DES、Blowfish 或 MD5 算法加密的字符串。

酒吧企业源码,ubuntu改为中文环境,地上生小爬虫,php周分享,太原seo标准lzw

在不同的操作系统上,该函数的行为不同,某些操作系统支持一种以上的算法类型。在安装时,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)

参数描述

str 必需。规定要编码的字符串。

salt 可选。用于增加被编码字符数目的字符串,以使编码更加安全。如果未提供 salt 参数,则每次调用该函数时会随机生成一个。

技术细节

返回值: 返回加密字符串,如果失败则返回一个小于 13 个字符并保证不同于 salt 的字符串。

PHP 版本: 4+

更新日志: 在 PHP 5.3.7 中,新增了 $2x$ 和 $2y$ Blowfish 模式,用来处理潜在的高位攻击。

在 PHP 5.3.2 中,新增了常量 SHA-256 和 SHA-512。

自 PHP 5.3.2 起,Blowfish 在无效的循环将返回 “failure” 字符串(”*0″ 或 “*1″),而不是后退到 DES。

自 PHP 5.3.0 起,PHP 自带 MD5 加密实现、标准 DES 实现、扩展 DES 实现以及 Blowfish 算法。如果系统不支持上述的算法,将使用 PHP 自带的算法实现。

实例

实例 1

在本实例中,我们将测试不同的算法:

<?php// 2 character saltif (CRYPT_STD_DES == 1){echo "Standard DES: ".crypt(something,st)."n

"; }else{echo "Standard DES not supported.n

";}// 4 character saltif (CRYPT_EXT_DES == 1){echo "Extended DES: ".crypt(something,\_S4..some)."n

";}else{echo "Extended DES not supported.n

";}// 12 character salt starting with $1$ if (CRYPT_MD5 == 1){echo "MD5: ".crypt(something,$1$somethin$)."n

"; }else{echo "MD5 not supported.n

";}// Salt starting with $2a$. The two digit cost parameter: 09. 22 characters if (CRYPT_BLOWFISH == 1){echo "Blowfish: ".crypt(something,$2a$09$anexamplestringforsalt$)."n

"; }else{echo "Blowfish DES not supported.n

";}// 16 character salt starting with $5$. The default number of rounds is 5000.if (CRYPT_SHA256 == 1) {echo "SHA-256: ".crypt(something,$5$rounds=5000$anexamplestringforsalt$)."n

"; }else{echo "SHA-256 not supported.n

";}// 16 character salt starting with $5$. The default number of rounds is 5000.if (CRYPT_SHA512 == 1) {echo "SHA-512: ".crypt(something,$6$rounds=5000$anexamplestringforsalt$); }else{echo "SHA-512 not supported.";}?>

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

Standard DES: stqAdD7zlbByIExtended DES: _S4..someQXidlBpTUu6MD5: $1$somethin$4NZKrUlY6r7K7.rdEOZ0w.Blowfish: $2a$09$anexamplestringforsaleLouKejcjRlExmf1671qw3Khl49R3dfuSHA-256: $5$rounds=5000$anexamplestringf$KIrctqsxo2wrPg5Ag/hs4jTi4PmoNKQUGWFXlVy9vu9SHA-512: $6$rounds=5000$anexamplestringf$Oo0skOAdUFXkQxJpwzO05wgRHG0dhuaPBaOU/oNbGpCEKlf/7oVM5wn6AN0w2vwUgA0O24oLzGQpp1XKI6LLQ0.

A、代码

<?php $str = 应用crypt()函数进行单向加密!;//声明字符串变量$str echo 加密前$str的值为:.$str; $crypttostr = crypt($str);//对变量$str加密 echo

加密后$str的值为:.$crypttostr; //输出加密后的变量 ?>

B、运行结果

参数不带salt,每次加密得出的密文都不一样。

加密前$str的值为:应用crypt()函数进行单向加密!

加密后$str的值为:$1$Re4.Gg4.$D.yd00xX0fFfIfp6KrKGN0

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。