Maison > Article > développement back-end > 有关php中加密函数的一些总结
本文介绍下,php中有关加密的一些函数用法,有需要的朋友,参考下吧。
在php中实现加密的函数,不外乎如下: 1,md5() 2,sha1() 3,crc32() 4,crypt() 5,uniqid() 1,md5()函数 定义和用法 md5() 函数计算字符串的 MD5 散列。 md5() 函数使用 RSA 数据安全,包括 MD5 报文摘译算法。 如果成功,则返回所计算的 MD5 散列,如果失败,则返回 false。 语法 md5(string,raw) 参数 描述 string 必需。规定要计算的字符串。 raw raw 可选。规定十六进制或二进制输出格式: TRUE - 原始 16 字符二进制格式 FALSE - 默认。32 字符十六进制数 注释:该参数是 PHP 5.0 中添加的。 例子: <?php $str = "Hello"; echo md5($str); ?> 输出: 8b1a9953c4611296a827abf8c47804d7 2,sha1()函数: 定义和用法 sha1() 函数计算字符串的 SHA-1 散列。 sha1() 函数使用美国 Secure Hash 算法 1。 如果成功,则返回所计算的 SHA-1 散列,如果失败,则返回 false。 语法 sha1(string,raw) 参数 描述 string 必需。规定要计算的字符串。 charlist 可选。规定十六进制或二进制输出格式: TRUE - 原始 20 字符二进制格式 FALSE - 默认。40 字符十六进制数 注释:该参数是 PHP 5.0 中添加的。 3,crc32()函数: 定义和用法 crc32() 函数计算一个字符串的 crc32 多项式。 该函数可用于验证数据的完整性。 语法 crc32(string) string必需。规定要计算的字符串。 说明 生成 string 参数的 32 位循环冗余校验码多项式。这通常用于检查传输的数据是否完整。 提示和注释 提示:由于 PHP 的整数是带符号的,许多 crc32 校验码将返回负整数,因此您需要使用 sprintf() 或 printf() 的 "%u" 格式符来获取表示无符号 crc32 校验码的字符串。 例子,将在使用以及不使用 "%u" 格式符的情况下,输出 crc32() 的结果(注意结果是相同的): <?php $str = crc32("Hello world!"); echo 'Without %u: '.$str."<br />"; echo 'With %u: '; printf("%u",$str); ?> 输出: Without %u: 461707669 With %u: 461707669 例2,在本例中,将在使用以及不使用 "%u" 格式符的情况下,输出 crc32() 的结果(注意结果是不相同的): <?php $str = crc32("Hello world."); echo 'Without %u: '.$str."<br />"; echo 'With %u: '; printf("%u",$str); ?> 输出: Without %u: -1959132156 With %u: 2335835140 4,uniqid()函数: 定义和用法 uniqid() 函数基于以微秒计的当前时间,生成一个唯一的 ID。 语法 uniqid(prefix,more_entropy) prefix可选。为 ID 规定前缀。如果两个脚本在相同的微妙生成 ID,该参数很有用。 more_entropy可选。规定位于返回值末尾的更多的熵。 说明 如果 prefix 参数为空,则返回的字符串有 13 个字符串长。如果 more_entropy 参数设置为 true,则是 23 个字符串长。 如果 more_entropy 参数设置为 true,则在返回值的末尾添加额外的熵(使用组合线形同余数生成程序),这样可以结果的唯一性更好。 返回值 以字符串的形式返回唯一标识符。 提示和注释 注释:由于基于系统时间,通过该函数生成的 ID 不是最佳的。如需生成绝对唯一的 ID,请使用 md5() 函数(请在字符串函数参考中查找)。 例子: <?php echo uniqid(); ?> 输出类似: 4415297e3af8c 5,crypt()函数: 定义和用法 crypt() 函数返回使用 DES、Blowfish 或 MD5 加密的字符串。 在不同的操作系统上,本函数的行为不同,某些操作系统支持一种以上的算法类型。在安装时,PHP 会检查什么算法可用以及使用什么算法。 语法 crypt(str,salt) str必需。规定要编码的字符串。 salt 可选。用于增加被编码字符数目的字符串,以使编码更加安全。 如果未提供 salt 参数,则每次调用该函数时会随机生成一个。 提示和注释 提示:解密函数是没有的。crypt() 函数使用一种单向算法。 例子,将测试不同的算法: <?php if (CRYPT_STD_DES == 1) { echo "Standard DES: ".crypt("hello world")."\n<br />"; } else { echo "Standard DES not supported.\n<br />"; } if (CRYPT_EXT_DES == 1) { echo "Extended DES: ".crypt("hello world")."\n<br />"; } else { echo "Extended DES not supported.\n<br />"; } if (CRYPT_MD5 == 1) { echo "MD5: ".crypt("hello world")."\n<br />"; } else { echo "MD5 not supported.\n<br />"; } if (CRYPT_BLOWFISH == 1) { echo "Blowfish: ".crypt("hello world"); } else { echo "Blowfish DES not supported."; } ?> 输出类似(依赖于操作系统): Standard DES: $1$r35.Y52.$iyiFuvM.zFGsscpU0aZ4e. Extended DES not supported. MD5: $1$BN1.0I2.$8oBI/4mufxK6Tq89M12mk/ Blowfish DES not supported. 说明,确切的算法依赖于 salt 参数的格式和长度。 以下是与 crypt() 函数一起使用的一些常量。 在安装时,由 PHP 设置这些常量: [CRYPT_SALT_LENGTH] [CRYPT_STD_DES] [CRYPT_EXT_DES] [CRYPT_MD5] [CRYPT_BLOWFISH] |