PHP密码验证:_password_verify使用教程
2026-04-14 23:12:51
0浏览
收藏
本文深入解析了PHP中`password_verify()`函数的使用要点与常见陷阱,明确指出其返回`false`的绝大多数情况并非代码逻辑错误,而是密码原文或哈希值在存储、传输、读取过程中被意外截断、污染或处理(如混入不可见字符、误用`trim()`、参数顺序颠倒、算法不兼容等);该函数具备自动识别哈希标识(如`$2y$`、`$argon2id$`)的能力,无需手动解析算法或盐值,兼容bcrypt和Argon2等多种哈希格式,且向后兼容性良好;真正的问题往往藏在数据流转的“前一环”——从数据库字段长度设置、编码转换到表单输入处理,都可能悄然破坏哈希完整性,因此调试时应优先验证数据本身而非修改验证逻辑。

password_verify() 验证失败的常见原因
直接说结论:password_verify() 返回 false,90% 不是函数写错了,而是密码原文或哈希值本身有问题。
它只做一件事:用明文密码 + 已存储的哈希字符串(含算法、盐、轮数),重算一次哈希,再比对。只要两边不完全一致,就返回 false。
- 哈希字符串被截断(比如数据库字段设成
VARCHAR(60),但bcrypt哈希实际要 60 字符,argon2id可能更长) - 哈希字符串里混入了空格、换行、BOM 或不可见控制字符(尤其从表单/文件读取时)
- 密码原文在验证前被 trim()、strtolower() 等处理过,而当初 hash 时没这么干
- 用了
password_hash()的默认算法(目前是bcrypt),但旧系统存的是md5或sha1——password_verify()完全不认这些
password_verify() 的参数顺序不能反
函数签名是 password_verify(string $password, string $hash): bool,第一个是用户输入的明文密码,第二个是数据库里存的完整哈希字符串。
顺序反了不会报错,但一定返回 false —— 因为 PHP 会尝试把哈希当密码、把明文当哈希去解析,而明文显然不含 $2y$ 或 $argon2id$ 这类标识头。
- 错误写法:
password_verify($hash_from_db, $user_input) - 正确写法:
password_verify($user_input, $hash_from_db) - 建议变量命名带提示,比如叫
$plain_password和$stored_hash,别用$pwd和$str
验证前不需要知道用了哪种算法
password_verify() 能自动识别哈希字符串开头的标识,比如 $2y$(bcrypt)、$argon2id$(Argon2),并调用对应逻辑。你不用手动判断或分支处理。
这意味着:只要哈希是用 password_hash() 生成的(且没被破坏),无论当年用的是 PASSWORD_DEFAULT 还是显式指定 PASSWORD_ARGON2ID,现在都能验。
- 兼容性没问题:PHP 7.2+ 支持
argon2,7.0+ 支持bcrypt;老哈希在新 PHP 上照常能验 - 但注意:
PASSWORD_DEFAULT未来可能变,默认算法升级后,旧密码仍可验,新密码会用新算法生成 - 不要自己 parse
$hash去提取 salt 或 cost ——password_verify()内部全做了,也禁止外部干预
验证失败时别急着改代码,先检查数据流
最常被忽略的环节是:哈希根本没存进数据库,或者读出来的时候就被截断、转义、编码转换污染了。
加一行调试输出,比反复改逻辑有用得多:
var_dump([
'input' => $user_password,
'hash_length' => strlen($stored_hash),
'hash_preview' => substr($stored_hash, 0, 20),
'hash_valid' => password_verify($user_password, $stored_hash)
]);
- 看
hash_length:bcrypt 应该是 60,argon2id 通常 ≥ 90;少于 60 基本就是字段太短 - 看
hash_preview:开头是不是$2y$或$argon2id$?如果不是,说明存进去的就是错的 - 确认数据库连接没启用
magic_quotes类老古董配置,也没对字段做自动utf8mb4截断
真正卡住的地方,往往不在 password_verify() 本身,而在它拿到的数据之前那一小段路。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《PHP密码验证:_password_verify使用教程》文章吧,也可关注golang学习网公众号了解相关技术文章。
Pythonmmap()函数使用技巧与详解
- 上一篇
- Pythonmmap()函数使用技巧与详解
- 下一篇
- 如何下载网页为HTM文件方法
查看更多
最新文章
-
- 文章 · php教程 | 4小时前 |
- PHP创建稀疏表方法解析
- 233浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- PHPCI/CD自动化部署流程全解析
- 368浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- Slim框架搭建API接口教程
- 493浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- HPAI打印PHP集成技巧解析
- 238浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- PHP反射性能优化技巧分享
- 234浏览 收藏
-
- 文章 · php教程 | 5小时前 |
- PHP表单安全验证与数据过滤技巧
- 114浏览 收藏
-
- 文章 · php教程 | 5小时前 |
- Slim全局中间件过滤请求教程
- 152浏览 收藏
-
- 文章 · php教程 | 5小时前 |
- 短链接还原PHP教程及实战方法
- 429浏览 收藏
-
- 文章 · php教程 | 5小时前 |
- PHP计算阶乘失败怎么解决?
- 269浏览 收藏
-
- 文章 · php教程 | 5小时前 |
- PHP获取网卡型号信息方法详解
- 105浏览 收藏
-
- 文章 · php教程 | 6小时前 |
- PHP如何接收POST请求参数与表单处理
- 284浏览 收藏
-
- 文章 · php教程 | 6小时前 |
- Laravel缓存超时随机偏移防雪崩方法
- 378浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 4285次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 4642次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 4523次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 6247次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 4901次使用
查看更多
相关文章
-
- PHP技术的高薪回报与发展前景
- 2023-10-08 501浏览
-
- 基于 PHP 的商场优惠券系统开发中的常见问题解决方案
- 2023-10-05 501浏览
-
- 如何使用PHP开发简单的在线支付功能
- 2023-09-27 501浏览
-
- PHP消息队列开发指南:实现分布式缓存刷新器
- 2023-09-30 501浏览
-
- 如何在PHP微服务中实现分布式任务分配和调度
- 2023-10-04 501浏览

