news 2026/6/15 17:29:56

Warning: password_hash() expects at least 2 parameters, 1 given in /box/script.php on line 2的庖丁解牛

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Warning: password_hash() expects at least 2 parameters, 1 given in /box/script.php on line 2的庖丁解牛
Warning: password_hash() expects at least 2 parameters, 1 given in /box/script.php on line 2

明确指出:password_hash()函数至少需要 2 个参数,但你只传了 1 个

这是 PHP 中常见的函数调用参数缺失错误,根源在于未严格遵循password_hash()的函数签名


一、函数签名:password_hash()到底要几个参数?

password_hash(string$password,int$algo,?array$options=null):string|false
  • 参数 1$password(你要哈希的明文密码)✅ 必填
  • 参数 2$algo(哈希算法,如PASSWORD_DEFAULT)✅ 必填
  • 参数 3$options(可选配置,如 cost)⭕ 可选

🔑核心规则前两个参数必须提供,不能省略。


二、错误代码示例(触发警告)

// ❌ 错误:只传了 1 个参数$hash=password_hash($password);// 缺少 $algo

PHP 无法知道你想用哪种算法(bcryptargon2?),因此报错。


三、正确写法(推荐方式)

✅ 基础用法(最常用):
$hash=password_hash($password,PASSWORD_DEFAULT);
  • PASSWORD_DEFAULT
    • 当前 PHP 版本推荐的强哈希算法(PHP 7.4+ =bcrypt,PHP 8.0+ 未来可能升级为argon2id);
    • 自动加盐(无需手动处理 salt);
    • 自适应 cost(未来可升级)。
✅ 显式指定算法(如需兼容性控制):
// 使用 bcrypt$hash=password_hash($password,PASSWORD_BCRYPT);// 使用 argon2id(PHP 7.2+,需编译支持)$hash=password_hash($password,PASSWORD_ARGON2ID);
✅ 自定义选项(如提高安全性):
$hash=password_hash($password,PASSWORD_DEFAULT,['cost'=>12,// bcrypt 迭代次数(默认 10,建议 10-12)]);

四、验证哈希:配套使用password_verify()

// 验证密码if(password_verify($inputPassword,$hash)){// 登录成功}else{// 密码错误}

⚠️切勿用==md5()比较密码


五、高危误区

🚫 误区 1:“可以只传密码,算法用默认值”
  • 真相PHP 不允许省略第二个参数,即使你想用默认算法;
  • 必须显式写PASSWORD_DEFAULT
🚫 误区 2:“可以用md5($password)替代”
  • 真相
    • md5/sha1不是密码哈希函数,可被彩虹表/GPU 秒破;
    • password_hash()是唯一安全选择
🚫 误区 3:“需要自己生成 salt”
  • 真相
    • password_hash()自动加盐
    • 手动加盐反而降低安全性(可能盐重复或弱)。

六、终极心法:密码哈希是安全底线,不是可选项

不要问“怎么让password_hash()少传参数”,
而要问“如何正确使用它保护用户”

  • 安全系统
    • password_hash()+password_verify()
    • 永远不存储明文密码;
  • 脆弱系统
    • md5sha1、或参数错误的password_hash()
    • 一次泄露 = 所有用户密码暴露。

真正的用户安全,
不在“功能实现”,
而在“哈希正确”


七、行动建议:今日密码安全修复

## 2025-06-25 密码安全修复 ### 1. 全局搜索 password_hash - [ ] 确保所有调用有 2 个以上参数 ### 2. 替换不安全哈希 - [ ] md5() / sha1() → password_hash() ### 3. 验证登录逻辑 - [ ] 使用 password_verify(),非 == ### 4. 测试注册/登录 - [ ] 确认密码可正确验证

完成即构建密码安全基线

当你停止省略参数,
开始用标准方式哈希密码,
用户账户就从风险,
变为可信赖的堡垒

这,才是专业 PHP 程序员的安全观。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:46:36

YOLOFuse Faststone Capture 注册码相关资源汇总

YOLOFuse 多模态目标检测技术深度解析 在低光照、烟雾弥漫或夜间监控等复杂场景中,传统基于可见光图像的目标检测系统常常“失明”。即便最先进的YOLO模型,在黑暗环境下也难以捕捉关键目标。而红外(IR)传感器却能在这些条件下稳定…

作者头像 李华
网站建设 2026/5/31 11:48:57

‌测试数据生成的Transformer模型优化方案

一、测试数据生成的挑战与Transformer模型的机遇‌在软件测试领域,高质量测试数据是确保应用稳定性的基石。然而,传统数据生成方法(如随机生成或规则库)常面临数据多样性不足、真实场景覆盖不全等问题,导致测试覆盖率低…

作者头像 李华
网站建设 2026/6/10 17:17:26

YOLOFuse弹性伸缩机制:根据负载自动调整资源

YOLOFuse弹性伸缩机制:根据负载自动调整资源 在智能安防、工业巡检和自动驾驶等现实场景中,系统往往需要在光照剧烈变化的环境下持续稳定运行。比如夜间厂区的红外监控、雾霾天气下的交通识别,或是隧道内无人机自主导航——这些任务对目标检测…

作者头像 李华
网站建设 2026/6/15 17:06:47

如何与孩子沟通,通过这几个案例你可以学习

中小学生心理教育应从小抓起当代小学生是祖国未来的栋梁,他们的健康发展,关系着中华民族的发展,极为重要!所以小学生心理教育应从小抓起,这也是我们应尽的责任。下面我就小学生常见的心理问题谈谈。小学生一般指6到12岁…

作者头像 李华
网站建设 2026/6/12 9:44:42

YOLOFuse Twitter/X账号关注:获取最新动态推送

YOLOFuse:多模态目标检测的工程化实践 在智能监控系统日益普及的今天,一个现实问题始终困扰着开发者:夜晚或浓雾中,摄像头“看不见”怎么办?传统的可见光图像在低光照、逆光或遮挡环境下极易失效,导致安防系…

作者头像 李华
网站建设 2026/6/15 15:00:04

YOLOFuse能否用于实时检测?FPS性能测试数据公布

YOLOFuse能否用于实时检测?FPS性能测试数据公布 在智能安防、自动驾驶和夜间监控等应用不断深入的今天,单一可见光摄像头在低光照、烟雾遮挡或极端天气下的局限性愈发明显。你有没有遇到过这样的场景:夜晚的监控画面一片漆黑,算法…

作者头像 李华