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 加密有一个以 $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 的数字值用于表示散列循环被执行的次数,这与 Blowfish 中的 cost 参数类似。默认的循环次数是 5000,最小值是 1000,最大值是 999,999,999。任何超出这个范围的 N 的值将会转换成最接近的边界值。

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

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

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

语法

crypt( _str,salt_ )

实例 1

得到的完整结果作为盐值进行密码校验,以此来避免使用不同散列算法导致的问题。(如上所述,基于标准 DES 算法的密码散列使用 2 字符盐值,但是基于 MD5

算法的散列使用 12 个字符盐值。)*/ if (hash_equals($hashed_password, crypt($user_input,

$hashed_password))) { echo "Password verified!"; } ?>

实例 2

利用 htpasswd 进行 crypt() 加密:

crypt($password); ?>

实例 1

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

'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:          $1$rasmusle$rISCgZzpwk3UhDidwXvin0

Blowfish:     $2a$07$usesomesillystringfore2uDLvp1Ii2e./U9C8sBjqp8I90dH6hi

SHA-256:      $5$rounds=5000$usesomesillystri$KqJWpanXZHKq2BOB43TSaYhEWsQ1Lr5QNyPCDH/Tp.6

SHA-512:      $6$rounds=5000$usesomesillystri$D4IrlXatmP7rx3P3InaxBeoomnAihCKRVQP22JZ6EY47Wc6BkroIuUUBOov1i.S5KPgErtP/EN5mcO.ChWQW21

总结

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

php crypt加密 盐值,PHP crypt()函数的用法讲解相关推荐

  1. php crypt加密 盐值,crypt()函数

    标签: 数据加密 数据加密利用密码技术对信息进行加密,实现信息的隐蔽,从而起到保护信息安全的作用.它通过加密算法和加密秘钥将原来是明文的文件或数据进行处理,使其成文不可读的一段代码,也就是所谓的&qu ...

  2. python列表split_Python-split()函数实例用法讲解

    在Python中,split() 方法可以实现将一个字符串按照指定的分隔符切分成多个子串,这些子串会被保存到列表中(不包含分隔符),作为方法的返回值反馈回来. split函数用法 split(sep= ...

  3. Shiro密码加密 盐值加密

    1.为什么要盐值加密 对于同一密码,同一加密算法会产生相同的hash值.这样,当用户进行身份验证时,对用户输入的明文密码应用相同的hash加密算法,得出一个hash值,然后使用该hash值和之前存储好 ...

  4. python里map函数_python中map()函数的用法讲解

    原博文 2018-10-26 12:59 − map函数的原型是map(function, iterable, -),它的返回结果是一个列表. 参数function传的是一个函数名,可以是python ...

  5. 一种随机生成加密盐值的方法

    密码加密的时候,可以选择性的添加随机值与密码明文拼接,然后md5加密,获得加密后的密码.下面是一种获得随机值的方法: public static String getRandomSalt() { St ...

  6. 求两者较大值的max函数的用法(c++基础)

    题目描述: 输入两个整数,比较大小并输出"max=",之后输出较大的值. 输入格式: 两个整数,用逗号分隔. 输出格式: 请输出读入的两个整数的较大值,并在较大值之前输出" ...

  7. transpose公式_tf.transpose函数的用法讲解(图解)

    tf.transpose函数中文意思是转置,对于低维度的转置问题,低维的还可以理解高维有点懵 看了博客也不是很明白 tf.transpose函数 tf.transpose( a, perm=None, ...

  8. tf 矩阵行和列交换_tf.transpose函数的用法讲解

    tf.transpose函数中文意思是转置,对于低维度的转置问题,很简单,不想讨论,直接转置就好(大家看下面文档,一看就懂). tf.transpose(a, perm=None, name='tra ...

  9. java shiro盐值加密_java中spring-shiro实现密码的MD5盐值加密

    看了网上很多教程,都提到有配置spring shiro的密码加密方式,甚至给出了自定义的Class来实现.却很少有通过配置来解决的. 密码的盐值加密方式应该是非常通用的,也可以算是基础吧.按理说spr ...

最新文章

  1. Intellij IDEA 使用Spring-boot-devTools无效解决办法
  2. matlab安装配置VLFeat库
  3. 计算机应用问题,计算机应用的现状与发展的问题
  4. OpenCV Stitching 工程搭建
  5. 第九十六期:JavaScript 中的 4 个相等比较算法的介绍
  6. 【ZOJ - 3872】Beauty of Array(思维,计算贡献,枚举)
  7. Java-自增自减运算符 初始Math类
  8. Java 8 新增lambda表达式(-)
  9. 在windows下安装webpy
  10. linux时间与日期函数,Linux时间日期函数
  11. 阿呆做网站(1)--基本功能
  12. 好好讲一讲:到底什么是Java架构师(含福利放送,名额有限)
  13. Ubuntu: Ubuntu中安装使用Source Inside 3.5
  14. smtp邮件服务器的作用,smtp服务器是什么意思(smtp服务器作用及使用指南)
  15. Windows安装Jenkins msi文件时,用户无法授权通过验证解决方法
  16. 灰色系统理论(Matlab实现)
  17. 错误排查:Cloudera Manager Agent 的 Parcel 目录位于可用空间小于 10.0 吉字节 的文件系统上。 /opt/cloudera/parcels...
  18. 【ONNX】使用 C++ 调用 ONNX 格式的 PyTorch 深度学习模型进行预测(Windows, C++, PyTorch, ONNX, Visual Studio, OpenCV)
  19. iphone铃声android铃声,iphone12如何设置铃声?iphone12更换铃声方式分享[多图]
  20. Poto Editor for Mac(mac照片编辑器)

热门文章

  1. 博客积分规则 博客等级
  2. Report20200828螺旋波等离子体推力器HPT模拟放电调试小结
  3. [云炬学英语]每日一句2020.8.28
  4. [云炬python3玩转机器学习]5-10 更多关于线性回归的讨论
  5. 燃烧学往年精选真题解析
  6. 涵盖 14 大主题!最完整的 Python 学习实例集来了!
  7. 将servlet数据传到html_Servlet详解(二)
  8. python嵌套字典代码_python – 尝试在嵌套字典中查找唯一值的总和. (见例子!)
  9. 十大开源推荐系统简介 [转自oschina]
  10. Python1:if / while / for...in / break /continue