前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PHP crypt()函数的用法讲解

PHP crypt()函数的用法讲解

作者头像
砸漏
发布2020-10-21 10:29:31
1.9K0
发布2020-10-21 10:29:31
举报
文章被收录于专栏:恩蓝脚本

PHP crypt() 函数

定义和用法

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

在不同的操作系统上,该函数的行为不同,某些操作系统支持一种以上的算法类型。在安装时,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 加密有一个以 2a2x2y 开始的 salt,一个两位数的 cost 参数 “”,以及来自字母表 “./0-9A-Za-z” 中的 22 个字符。使用字母表以外的字符将引发函数返回一个长度为 0 的字符串。”” 参数是以 2 为底的基于 Blowfish 散列算法的迭代次数的对数,必须在 04-31 范围内。在该范围以外的值将引发函数失败。
  • [CRYPT_SHA_256] – SHA-256 加密有 16 个字符的 salt,以 5 开始。如果 salt 字符串以 “rounds=
  • [CRYPT_SHA_512] – SHA-512 加密有 16 个字符的 salt,以 6 开始。 如果 salt 字符串以 “rounds=

在该函数支持多种算法的系统上,上面的常量如果支持则设置为 “1”,否则设置为 “0”。

注释: 没有相应的解密函数。crypt() 函数使用一种单向算法。

语法

代码语言:javascript
复制
crypt( _str,salt_ )

实例 1

代码语言:javascript
复制
<?php $hashed_password = crypt('mypassword'); // 自动生成盐值 /* 你应当使用 crypt()
得到的完整结果作为盐值进行密码校验,以此来避免使用不同散列算法导致的问题。(如上所述,基于标准 DES 算法的密码散列使用 2 字符盐值,但是基于 MD5
算法的散列使用 12 个字符盐值。)*/ if (hash_equals($hashed_password, crypt($user_input,
$hashed_password))) { echo "Password verified!"; } ? 

实例 2

利用 htpasswd 进行 crypt() 加密:

代码语言:javascript
复制
<?php // 设置密码 $password = 'mypassword'; // 获取散列值,使用自动盐值 $hash =
crypt($password); ? 

实例 1

在本实例中,我们以不同散列类型使用:

代码语言:javascript
复制
<?php if (CRYPT_STD_DES == 1) { echo 'Standard DES: ' . crypt('rasmuslerdorf',
'rl') . "\n"; } if (CRYPT_EXT_DES == 1) { echo 'Extended DES: ' .
crypt('rasmuslerdorf', '_J9..rasm') . "\n"; } if (CRYPT_MD5 == 1) { echo 'MD5:
' . crypt('rasmuslerdorf', '$1$rasmusle$') . "\n"; } if (CRYPT_BLOWFISH == 1)
{ echo 'Blowfish: ' . crypt('rasmuslerdorf',
'$2a$07$usesomesillystringforsalt$') . "\n"; } if (CRYPT_SHA256 == 1) { echo
'SHA-256: ' . crypt('rasmuslerdorf',
'$5$rounds=5000$usesomesillystringforsalt$') . "\n"; } if (CRYPT_SHA512 == 1)
{ echo 'SHA-512: ' . crypt('rasmuslerdorf',
'$6$rounds=5000$usesomesillystringforsalt$') . "\n"; } ? 

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

Standard DES: rl.3StKT.4T8M Extended DES: _J9..rasmBYk8r9AiWNc MD5: 1rasmuslerISCgZzpwk3UhDidwXvin0 Blowfish: 2a07usesomesillystringfore2uDLvp1Ii2e./U9C8sBjqp8I90dH6hi SHA-256: 5rounds=5000usesomesillystriKqJWpanXZHKq2BOB43TSaYhEWsQ1Lr5QNyPCDH/Tp.6 SHA-512: 6rounds=5000usesomesillystriD4IrlXatmP7rx3P3InaxBeoomnAihCKRVQP22JZ6EY47Wc6BkroIuUUBOov1i.S5KPgErtP/EN5mcO.ChWQW21

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对ZaLou.Cn的支持。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档