Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

PHP 教程

PHP 主页 PHP 简介 PHP 安装 PHP 语法 PHP 注释 PHP 变量 PHP Echo / Print PHP 数据类型 PHP 字符串 PHP 数字 PHP 类型转换 PHP 数学 PHP 常量 PHP 魔术常量 PHP 运算符 PHP If...Else...Elseif PHP Switch PHP 循环 PHP 函数 PHP 数组 PHP 超级全局变量 PHP 正则表达式

PHP 表单

PHP 表单处理 PHP 表单验证 PHP 表单必填 PHP 表单 URL/电子邮件 PHP 表单完成

PHP 高级

PHP 日期和时间 PHP Include PHP 文件处理 PHP 文件打开/读取 PHP 文件创建/写入 PHP 文件上传 PHP Cookies PHP 会话 PHP 过滤器 PHP 过滤器高级 PHP 回调函数 PHP JSON PHP 异常

PHP OOP

PHP 什么是 OOP PHP 类/对象 PHP 构造函数 PHP 析构函数 PHP 访问修饰符 PHP 继承 PHP 常量 PHP 抽象类 PHP 接口 PHP 特性 PHP 静态方法 PHP 静态属性 PHP 命名空间 PHP 可迭代对象

MySQL 数据库

MySQL 数据库 MySQL 连接 MySQL 创建数据库 MySQL 创建表 MySQL 插入数据 MySQL 获取最后 ID MySQL 插入多个数据 MySQL 预处理语句 MySQL 选择数据 MySQL Where MySQL Order By MySQL 删除数据 MySQL 更新数据 MySQL 限制数据

PHP XML

PHP XML 解析器 PHP SimpleXML 解析器 PHP SimpleXML - 获取 PHP XML Expat PHP XML DOM

PHP - AJAX

AJAX 简介 AJAX PHP AJAX 数据库 AJAX XML AJAX 实时搜索 AJAX 投票

PHP 示例

PHP 示例 PHP 编译器 PHP 测验 PHP 练习 PHP 服务器 PHP 证书

PHP 参考

PHP 概述 PHP 数组 PHP 日历 PHP 日期 PHP 目录 PHP 错误 PHP 异常 PHP 文件系统 PHP 过滤器 PHP FTP PHP JSON PHP 关键字 PHP Libxml PHP 邮件 PHP 数学 PHP 杂项 PHP MySQLi PHP 网络 PHP 输出控制 PHP 正则表达式 PHP SimpleXML PHP 流 PHP 字符串 PHP 变量处理 PHP XML 解析器 PHP Zip PHP 时区

PHP crypt() 函数


❮ PHP 字符串参考

定义和用法

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

此函数在不同的操作系统上表现不同。 PHP 在安装时会检查哪些算法可用以及使用哪些算法。

salt 参数是可选的。但是,如果没有 salt,crypt() 会创建一个弱密码。确保为提高安全性指定足够强的 salt。

一些常量与 crypt() 函数一起使用。这些常量的值在 PHP 安装时由 PHP 设置。

常量

  • [CRYPT_STD_DES] - 基于标准 DES 的哈希,使用来自字母表“./0-9A-Za-z”的两个字符 salt。 在 salt 中使用无效字符会导致此函数失败。
  • [CRYPT_EXT_DES] - 基于扩展 DES 的哈希,使用九个字符的 salt,由下划线后跟 4 个字节的迭代计数和 4 个字节的 salt 组成。 这些被编码为可打印字符,每个字符 6 位,最低有效字符优先。 值 0 到 63 被编码为“./0-9A-Za-z”。 在 salt 中使用无效字符会导致函数失败。
  • [CRYPT_MD5] - 以 $1$ 开头的 12 个字符 salt 的 MD5 哈希
  • [CRYPT_BLOWFISH] - 以 $2a$、$2x$ 或 $2y$ 开头的 salt 的 Blowfish 哈希,一个两位数的成本参数“$”和来自字母表“./0-9A-Za-z”的 22 个字符。 在字母表之外使用字符会导致此函数返回一个零长度字符串。 “$”参数是底层 Blowfish 基于哈希算法的迭代计数的以 2 为底的对数,必须在 04-31 范围内。 此范围之外的值会导致函数失败。
  • [CRYPT_SHA_256] - 以 $5$ 开头的 16 个字符 salt 的 SHA-256 哈希。 如果 salt 字符串以“rounds=<N>$”开头,则 N 的数值用于指示哈希循环应执行多少次,类似于 Blowfish 上的成本参数。 默认轮数为 5000,最小值为 1000,最大值为 999,999,999。 此范围之外的任何 N 选择都将被截断到最接近的限制。
  • [CRYPT_SHA_512] - 使用 16 个字符的盐进行 SHA-512 哈希,盐以 $6 开头。如果盐字符串以“rounds=$”开头,则 N 的数值用于指示哈希循环应执行的次数,类似于 Blowfish 上的 cost 参数。默认循环次数为 5000 次,最小值为 1000 次,最大值为 999,999,999 次。任何超出此范围的 N 选择都将被截断到最近的限制。

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

注意:没有解密函数。crypt() 函数使用单向算法。


语法

crypt(str,salt)

参数值

参数 描述
str 必需。指定要哈希的字符串
salt 可选。用于对哈希进行基础运算的盐字符串


技术细节

返回值 返回编码后的字符串,或长度小于 13 个字符的字符串,该字符串在失败时保证与盐不同
PHP 版本 4+
变更日志 PHP 5.6.0 - 如果省略了salt,则显示 E_NOTICE 安全警告。
PHP 5.3.7 - 添加了 $2x$ 和 $2y$ Blowfish 模式。
PHP 5.3.2 - 添加了 SHA-256 和 SHA-512。修复了 Blowfish 在无效循环次数时返回“失败”字符串(“*0”或“*1”),而不是回退到 DES 的行为。
PHP 5.3.0 - PHP 现在包含了对 MD5 crypt、标准 DES、扩展 DES 和 Blowfish 算法的自身实现,如果系统缺少对一种或多种算法的支持,将使用该实现。

更多示例

示例

在本例中,我们将测试不同的算法

<?php
// 2 个字符的盐
if (CRYPT_STD_DES == 1)
{
echo "标准 DES: ".crypt('something','st')."\n<br>";
}
else
{
echo "标准 DES 不支持。\n<br>";
}

// 4 个字符的盐
if (CRYPT_EXT_DES == 1)
{
echo "扩展 DES: ".crypt('something','_S4..some')."\n<br>";
}
else
{
echo "扩展 DES 不支持。\n<br>";
}

// 以 $1$ 开头的 12 个字符的盐
if (CRYPT_MD5 == 1)
{
echo "MD5: ".crypt('something','$1$somethin$')."\n<br>";
}
else
{
echo "MD5 不支持。\n<br>";
}

// 以 $2a$ 开头的盐。两位数的 cost 参数:09。22 个字符
if (CRYPT_BLOWFISH == 1)
{
echo "Blowfish: ".crypt('something','$2a$09$anexamplestringforsalt$')."\n<br>";
}
else
{
echo "Blowfish DES 不支持。\n<br>";
}

// 以 $5$ 开头的 16 个字符的盐。默认循环次数为 5000 次。
if (CRYPT_SHA256 == 1)
{
echo "SHA-256: ".crypt('something','$5$rounds=5000$anexamplestringforsalt$')."\n<br>"; }
else
{
echo "SHA-256 不支持。\n<br>";
}

// 以 $6$ 开头的 16 个字符的盐。默认循环次数为 5000 次。
if (CRYPT_SHA512 == 1)
{
echo "SHA-512: ".crypt('something','$6$rounds=5000$anexamplestringforsalt$');
}
else
{
echo "SHA-512 不支持。" ;
}
?>

上述代码的输出可能为(取决于操作系统)

标准 DES: stqAdD7zlbByI
扩展 DES: _S4..someQXidlBpTUu6
MD5: $1$somethin$4NZKrUlY6r7K7.rdEOZ0w.
Blowfish: $2a$09$anexamplestringforsaleLouKejcjRlExmf1671qw3Khl49R3dfu
SHA-256: $5$rounds=5000$anexamplestringf$KIrctqsxo2wrPg5Ag/hs4jTi4PmoNKQUGWFXlVy9vu9
SHA-512: $6$rounds=5000$anexamplestringf$Oo0skOAdUFXkQxJpwzO05wgRHG0dhuaPBaOU/
oNbGpCEKlf/7oVM5wn6AN0w2vwUgA0O24oLzGQpp1XKI6LLQ0.


❮ PHP 字符串参考
×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2024 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.