php crypt()函数加密字符串

原创 国哥笔记  2019-01-03 20:09  阅读 508 views 次

crypt()函数定义及用法

在php中,crypt()函数是使用来使用DES、Blowfish或MD5算法加密字符串,返回加密后的字符串。该函数是一种单向算法,没有解密函数;

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

下面是一些和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>$" 开始,N 的数字值用于表示散列循环被执行的次数,这与 Blowfish 中的 cost 参数类似。默认的循环次数是 5000,最小值是 1000,最大值是 999,999,999。任何超出这个范围的 N 的值将会转换成最接近的边界值。
  • [CRYPT_SHA_512]:SHA-512 加密有 16 个字符的 salt,以 $6$ 开始。 如果 salt 字符串以 "rounds=<N>$" 开始,N 的数字值用于表示散列循环被执行的次数,这与 Blowfish 中的 cost 参数类似。默认的循环次数是 5000,最小值是 1000,最大值是 999,999,999。任何超出这个范围的 N 的值将会转换成最接近的边界值。

在crypt()函数支持多种算法的系统上,上面的常量如果支持则设置为 "1",否则设置为 "0";

crypt()函数语法格式

$str = crypt(str,salt);

参数说明:

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

更新日志

  • 在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自带的算法实现;

实例:

<?php
header("content-type:text/html;charset=utf-8");//设置编码,解决中文乱码
$string = "www.ggbiji.com";
$str = crypt($string);
echo "原字符串:".$string."<br/>";
echo "加密后的字符串:".$str;
?>

运行结果:

原字符串:www.ggbiji.com

加密后的字符串:$1$QZ2.ZF5.$22MTIXJE.fiVm9L.0v6KG.

 

说明:由于没有设置第二个参数,会随机生成一个,所以每次运行的结果不一样。

 

更多操作字符串的函数——>PHP String字符串函数大全

本文地址:https://www.ggbiji.com/php-crypt.html
版权声明:本文为 国哥笔记 原创/整理文章,欢迎分享,转载请注明出处!

发表评论


表情