对php中加密函数的总结

162 篇文章 0 订阅
89 篇文章 0 订阅

总的说来,能实现加密的函数有:

(1)md5()

 (2)sha1()

 (3)crc32()

 (4)crypt()

 (5)uniqid()

首先,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


 


其次来说sha1()函数:

定义和用法

sha1() 函数计算字符串的 SHA-1 散列。

sha1() 函数使用美国 Secure Hash 算法 1。

如果成功,则返回所计算的 SHA-1 散列,如果失败,则返回 false。

语法

sha1(string,raw)
参数描述
string必需。规定要计算的字符串。
charlist

可选。规定十六进制或二进制输出格式:

  • TRUE - 原始 20 字符二进制格式
  • FALSE - 默认。40 字符十六进制数

注释:该参数是 PHP 5.0 中添加的。

 

     

其次是crc32()函数:

定义和用法

crc32() 函数计算一个字符串的 crc32 多项式。

该函数可用于验证数据的完整性。

语法

crc32(string)

string必需。规定要计算的字符串。

说明

生成 string 参数的 32 位循环冗余校验码多项式。这通常用于检查传输的数据是否完整。

提示和注释

提示:由于 PHP 的整数是带符号的,许多 crc32 校验码将返回负整数,因此您需要使用 sprintf() 或 printf() 的 "%u" 格式符来获取表示无符号 crc32 校验码的字符串。

例子

例子 1

在本例中,我们将在使用以及不使用 "%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

 

然后是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

 

然后是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]

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 你可以使用 PHP 内置的函数进行加密,例如 hash() 和 password_hash()。 hash() 函数可以对字符串进行加密,例如: ``` $password = "secret"; $hash = hash("sha256", $password); ``` password_hash() 函数可以对密码进行加密,它是一个更安全的选择,并且它可以自动处理盐值: ``` $password = "secret"; $hash = password_hash($password, PASSWORD_DEFAULT); ``` 请确保使用适当的加密算法,并定期更新加密算法以保护数据的安全。 ### 回答2: PHP有许多不同的加密函数可供使用,我将选择使用常见的哈希函数来实现一个简单的加密函数。 首先,我们需要选择一个合适的哈希算法。SHA-256是一个常用的安全哈希算法,因此我们将使用它来加密数据。 我们可以创建一个名为encrypt的函数,该函数将接受一个字符串作为输入,并返回相应的加密哈希值。 ```php function encrypt($str) { // 使用SHA-256算法加密字符串 $encryptedStr = hash('sha256', $str); return $encryptedStr; } ``` 在这个函数,我们使用hash函数并指定SHA-256算法加密输入的字符串。 要使用这个加密函数,您只需传递您希望加密的字符串作为参数即可。 ```php $originalStr = 'hello world'; $encryptedStr = encrypt($originalStr); echo '原始字符串:' . $originalStr; echo '加密后的字符串:' . $encryptedStr; ``` 执行上述代码,输出将会是: 原始字符串:hello world 加密后的字符串:2ef7bde608ce5404e97d5f042f95f89f1c232871 注意,由于哈希函数是不可逆的,因此无法从加密后的字符串恢复原始的未加密字符串。所以,哈希函数通常用于检查数据的一致性和完整性,而不是为了保护数据的机密性。 ### 回答3: 要用PHP编写一个加密函数,我们可以使用现有的加密算法函数库来实现。以下是一个示例代码,使用MD5算法进行加密: ```php function encrypt($data) { $encryptedData = md5($data); return $encryptedData; } $plainText = 'Hello World'; $encryptedText = encrypt($plainText); echo '密文:' . $encryptedText; ``` 上述代码,我们定义了一个名为`encrypt`的函数,它接受一个数据作为参数。在该函数,我们使用`md5`函数对数据进行加密,并将加密后的数据返回。 我们可以调用`encrypt`函数,传入要加密的数据,然后打印出加密后的结果。在这个例子,我们对字符串"Hello World"进行加密,最后输出的结果为加密后的密文。 需要注意的是,MD5是一种单向散列函数,它将数据转化为固定长度的密文,但无法将密文转换回原始数据。因此,这个函数实现了加密功能,但不是可逆加密。 此外,我们还可以使用其他加密算法,如SHA1、AES等,具体取决于我们的需求和安全要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值