Heim  >  Artikel  >  Backend-Entwicklung  >  有关php中加密函数的一些总结

有关php中加密函数的一些总结

WBOY
WBOYOriginal
2016-07-25 08:58:13916Durchsuche
本文介绍下,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]



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn