
直接用 hexdec(),但必须注意前缀、大小写和非法字符——它不自动跳过空格或校验格式,输错就静默返回 0。
为什么 hexdec() 有时返回 0 而不是报错
这个函数遇到任何非十六进制字符(包括空格、0x 前缀、字母大小写混用但超出 a–f 范围)时,会从左开始解析,一碰到非法字符就停,剩余全丢弃;如果第一个字符就不合法,直接返回 0。
- 错误示例:
hexdec("0xff")→ 返回0(因为0x不被识别) - 错误示例:
hexdec("FFG")→ 返回255(只取前面FF,G截断) - 正确做法:手动清理前缀和空格,比如用
ltrim($str, "0xX \t\n\r")
大写字母和小写字母有区别吗
没有区别。hexdec() 对 a–f 和 A–F 一视同仁,大小写均可。但要注意:PHP 不做标准化处理,所以如果你后续要比较或存储,建议统一转小写(用 strtolower()),避免意外差异。
-
hexdec("aF")和hexdec("AF")都返回175 - 但
"Af"和"aF"在字符串层面不同,若用于缓存键或数组索引,可能引发逻辑偏差
超长十六进制字符串(比如 SHA256 哈希)能转吗
不能安全转成整数。PHP 的整数有平台限制(32 位系统最大约 21 亿,64 位系统约 9×10¹⁸),而一个 64 位十六进制数(如 "ffffffffffffffff")已远超该范围,hexdec() 会溢出并返回浮点数或截断值,结果不可靠。
立即学习“PHP免费学习笔记(深入)”;
- 例如:
hexdec("10000000000000000")在 64 位 PHP 中返回 float,不再是 int - 真实场景(如处理哈希、UUID、加密密钥)应保留为字符串,或用
gmp_init($str, 16)+gmp_strval()做任意精度计算 - 若只是校验或比较,根本不需要转十进制——直接字符串比对更快更准
最常被忽略的是输入校验环节:别假设传进来一定是干净的 hex 字符串,尤其来自表单、API 或日志解析时,多一个空格、少一个字符,hexdec() 就不声不响给你个 0。











