- PHP 教程
- PHP - 首页
- PHP - 简介
- PHP - 安装
- PHP - 历史
- PHP - 特性
- PHP - 语法
- PHP - Hello World
- PHP - 注释
- PHP - 变量
- PHP - Echo/Print
- PHP - var_dump
- PHP - $ 和 $$ 变量
- PHP - 常量
- PHP - 魔术常量
- PHP - 数据类型
- PHP - 类型转换
- PHP - 类型混杂
- PHP - 字符串
- PHP - 布尔值
- PHP - 整数
- PHP - 文件与 I/O
- PHP - 数学函数
- PHP - Heredoc 与 Nowdoc
- PHP - 复合类型
- PHP - 文件包含
- PHP - 日期与时间
- PHP - 标量类型声明
- PHP - 返回类型声明
- PHP 运算符
- PHP - 运算符
- PHP - 算术运算符
- PHP - 比较运算符
- PHP - 逻辑运算符
- PHP - 赋值运算符
- PHP - 字符串运算符
- PHP - 数组运算符
- PHP - 条件运算符
- PHP - 展开运算符
- PHP - 空值合并运算符
- PHP - 比较运算符(太空船运算符)
- PHP 控制语句
- PHP - 决策
- PHP - If…Else 语句
- PHP - Switch 语句
- PHP - 循环类型
- PHP - For 循环
- PHP - Foreach 循环
- PHP - While 循环
- PHP - Do…While 循环
- PHP - Break 语句
- PHP - Continue 语句
- PHP 函数
- PHP - 函数
- PHP - 函数参数
- PHP - 按值传递
- PHP - 按引用传递
- PHP - 默认参数
- PHP - 具名参数
- PHP - 可变参数
- PHP - 返回值
- PHP - 传递函数
- PHP - 递归函数
- PHP - 类型提示
- PHP - 变量作用域
- PHP - 严格类型
- PHP - 匿名函数
- PHP - 箭头函数
- PHP - 可变函数
- PHP - 局部变量
- PHP - 全局变量
- PHP 超全局变量
- PHP - 超全局变量
- PHP - $GLOBALS
- PHP - $_SERVER
- PHP - $_REQUEST
- PHP - $_POST
- PHP - $_GET
- PHP - $_FILES
- PHP - $_ENV
- PHP - $_COOKIE
- PHP - $_SESSION
- PHP 文件处理
- PHP - 文件处理
- PHP - 打开文件
- PHP - 读取文件
- PHP - 写入文件
- PHP - 文件是否存在
- PHP - 下载文件
- PHP - 复制文件
- PHP - 追加文件
- PHP - 删除文件
- PHP - 处理 CSV 文件
- PHP - 文件权限
- PHP - 创建目录
- PHP - 列出文件
- 面向对象的 PHP
- PHP - 面向对象编程
- PHP - 类和对象
- PHP - 构造函数和析构函数
- PHP - 访问修饰符
- PHP - 继承
- PHP - 类常量
- PHP - 抽象类
- PHP - 接口
- PHP - Traits
- PHP - 静态方法
- PHP - 静态属性
- PHP - 命名空间
- PHP - 对象迭代
- PHP - 封装
- PHP - Final 关键字
- PHP - 重载
- PHP - 克隆对象
- PHP - 匿名类
- PHP Web 开发
- PHP - Web 概念
- PHP - 表单处理
- PHP - 表单验证
- PHP - 表单邮件/URL
- PHP - 完整表单
- PHP - 文件包含
- PHP - GET & POST
- PHP - 文件上传
- PHP - Cookie
- PHP - Session
- PHP - Session 选项
- PHP - 发送邮件
- PHP - 净化输入
- PHP - Post-Redirect-Get (PRG)
- PHP - 闪存消息
- PHP 高级
- PHP - MySQL
- PHP.INI 文件配置
- PHP - 数组解构
- PHP - 编码规范
- PHP - 正则表达式
- PHP - 错误处理
- PHP - Try…Catch
- PHP - 调试 Bug
- PHP - 针对 C 开发人员
- PHP - 针对 PERL 开发人员
- PHP - 框架
- PHP - Core PHP vs. 框架
- PHP - 设计模式
- PHP - 过滤器
- PHP - JSON
- PHP - 异常
- PHP - 特殊类型
- PHP - 哈希
- PHP - 加密
- PHP - is_null() 函数
- PHP - 系统调用
- PHP - HTTP 认证
- PHP - 交换变量
- PHP - Closure::call()
- PHP - 过滤后的 unserialize()
- PHP - IntlChar
- PHP - CSPRNG
- PHP - 期望值
- PHP - Use 语句
- PHP - 整数除法
- PHP - 已弃用的特性
- PHP - 已移除的扩展和 SAPI
- PHP - PEAR
- PHP - CSRF
- PHP - FastCGI 进程
- PHP - PDO 扩展
- PHP - 内置函数
- PHP 有用资源
- PHP - 速查表
- PHP - 问答
- PHP - 快速指南
- PHP - 在线编译器
- PHP - 有用资源
- PHP - 讨论
PHP - Hash pbkdf2() 函数
定义和用法
hash_pbkdf2() 函数返回给定密码的 PBKDF2 密钥派生。
PBKDF2 代表基于密码的密钥派生函数 2。PBKDF2 密钥派生函数使用伪随机函数,例如基于哈希的消息认证码 (HMAC),它应用于给定的密码或消息以及盐值,并且该过程会迭代多次以获得密钥。它主要用于哈希密码,PBKDF2 密钥派生函数的设计使得攻击者难以猜测被哈希的原始密码。
语法
hash_pbkdf2 ( string $algo , string $password , string $salt , int $iterations [ , int $length = 0 [, bool $raw_output = FALSE ] ] ) : string
参数
序号 | 参数及描述 |
---|---|
1 |
algo 哈希算法的名称。hash 提供了大量的算法,一些重要的算法包括 md5、sha256 等。 要获取支持的完整算法列表,请查看 hash_algos() |
2 |
password 需要为其生成 PBKDF2 密钥派生的密码。 |
3 |
salt 要用于派生 PBKDF2 密钥派生的盐值。 |
4 |
iterations 为获得最终派生而执行的内部迭代次数。 |
5 |
length 最终 PBKDF2 密钥派生的长度。如果 raw_output 为 TRUE,则派生的密钥对应于字节长度;如果 raw_output 为 FALSE,则其将是派生密钥字节长度的两倍。 |
6 |
raw_output 如果 raw_output 为 false,则输出将是一个包含小写十六进制数的字符串;如果为 TRUE,则输出将是原始二进制数据。 |
返回值
hash_pbkdf2() 返回一个字符串,如果 raw_output 为 false,则该字符串包含派生密钥作为小写十六进制数;如果 raw_output 设置为 TRUE,则该字符串将是派生密钥的原始二进制表示。
PHP 版本
此函数适用于 PHP 5.5.0 以上版本。
示例 1
使用 hash_pbkdf2() -
<?php $password = "mypassword"; $iterations = 500; $salt = 'testingkey'; $pbkdf2_hash = hash_pbkdf2("md5", $password, $salt, $iterations, 25); echo $pbkdf2_hash; ?>
输出
这将产生以下结果:
cb0130970bb39f6a95d193934
示例 2
使用 1000 次迭代的 hash_pbkdf2() -
<?php $password = "mypassword"; $iterations = 1000; $salt = openssl_random_pseudo_bytes(10); //generates pseudo-random string of bytes $pbkdf2_hash = hash_pbkdf2("sha256", $password, $salt, $iterations, 10); echo $pbkdf2_hash; ?>
输出
这将产生以下结果:
0c31d20aa2
示例 3
使用 raw_output 为 true 的 hash_pbkdf2() -
<?php $password = "mypassword"; $iterations = 1000; $salt = openssl_random_pseudo_bytes(10); //generates pseudo-random string of bytes $pbkdf2_hash = hash_pbkdf2("sha256", $password, $salt, $iterations, 10, true); echo $pbkdf2_hash; ?>
示例 4
使用 raw_output 为 true 的 hash_pbkdf2() -
在本例中,我们将使用 base64_encode() PHP 函数,该函数将 hash_pbkdf2() 的原始二进制输出转换为可读字符串。
<?php echo base64_encode( hash_pbkdf2("sha256", 'passwordtest', openssl_random_pseudo_bytes(10), 5000, 10, true) ); ?>
输出
这将产生以下结果:
2FogGKtZxmt4iQ==