您的位置:首页 >PHP十六进制转十进制方法
发布于2026-03-17 阅读(0)
扫一扫,手机访问
hexdec()是最直接的十六进制转整型函数,但仅支持小写、无前缀格式;处理带前缀或大小写混用字符串需先用ltrim()和strtolower()清洗,并用ctype_xdigit()验证;超长十六进制(如SHA-256)应使用gmp_init()避免精度丢失。

PHP 内置的 hexdec() 函数专为十六进制字符串转整型设计,但它对输入格式很敏感:只接受纯数字字符(0-9 和 a-f),不接受大写字母、前缀(如 0x 或 #)、空格或任何其他符号。
hexdec("ff") → 255,hexdec("1a2b3c") → 1715004hexdec("0xFF") 返回 0(遇到 X 就停);hexdec("FF") 也返回 0(大写不识别)hexdec() 返回的是 float 类型(当值超过 PHP_INT_MAX 时),不是 int —— 这在 32 位系统或处理长哈希时容易出问题真实场景中,十六进制字符串常来自表单、API 响应或颜色值(如 "#a3cF12"、"0XDEADBEEF"),必须预处理。
ltrim() 去掉常见前缀:ltrim($hex, "0x#") 或更稳妥地用正则 preg_replace('/^0x|#|^0X/', '', $hex)strtolower() 必不可少,否则 hexdec() 会失败ctype_xdigit() 可判断清洗后字符串是否全为十六进制字符(注意它不接受空字符串)$raw = "#A3cF12";
$clean = strtolower(ltrim($raw, "0x#"));
if (ctype_xdigit($clean)) {
$num = hexdec($clean); // → 10735378
}hexdec() 在值过大时会退化为 float,精度丢失。比如 hexdec("ffffffffffffffff") 在 64 位 PHP 上可能还行,但 "deadbeefdeadbeefdeadbeefdeadbeef"(32 字符)必然溢出,结果不可信。
gmp_init() + gmp_strval()(需启用 GMP 扩展):$big = gmp_init("deadbeef", 16);
$num = gmp_strval($big, 10); // 字符串形式的十进制数base_convert(),但它也有长度限制(内部用 int 运算,仍可能溢出)有人看到十六进制字符串,下意识用 pack("H*", $hex) 再 unpack(),这是把“表示十六进制的字符串”误当成“十六进制编码的二进制流”了。
unpack("N", pack("H*", "000000ff")) → 试图把字符串 "000000ff" 当作字节序列解析,实际得到的是 0x30 0x30 0x30 0x30 0x30 0x30 0x66 0x66(ASCII 码)hexdec() 或 GMP 转成数值,再按需 pack();或者用 hex2bin() 把真正以十六进制编码的二进制字符串(如 API 返回的 "a3f1" 表示两个字节 0xa3 0xf1)转出来,再 unpack()hexdec() 解释「字符串内容是十六进制」;hex2bin() 解码「字符串本身是十六进制编码的二进制」
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9