CleverCode最近遇到一个PHP项目整形转化问题,mysql有一个字段id是bigint的,里面有长整型,如id = 5147486396。但是php代码由于历史原因却部署在多台机器中,其中A机器32位系统中,B机器64系统中。现在的问题是64系统中页面访问正常。32位系统中访问出错了。原因是php整形溢出。
1 A机器演示
1.1 获取A机器系统位数
# getconf LONG_BIT
1.2 整形转化代码
<?php
$id = 5147486396;
echo '$id:'.$id."\r\n";
$value = (int)$id;
echo '(int)$id:'.$value."\r\n";
$value = intval($id);
echo 'intval($id):'.$value."\r\n";
$value = filter_var($id, FILTER_VALIDATE_INT);
echo 'filter_var($id, FILTER_VALIDATE_INT):'."\r\n";
var_dump($value);
?>
1.3 运行结果
(int)5147486396的结果是852519100,intval(5147486396)的结果是852519100,filter_var(5147486396, FILTER_VALIDATE_INT)结果是false。
2 B机器演示
2.1 获取B机器系统位数
# getconf LONG_BIT
2.2 整形转化代码
<?php
$id = 5147486396;
echo '$id:'.$id."\r\n";
$value = (int)$id;
echo '(int)$id:'.$value."\r\n";
$value = intval($id);
echo 'intval($id):'.$value."\r\n";
$value = filter_var($id, FILTER_VALIDATE_INT);
echo 'filter_var($id, FILTER_VALIDATE_INT):'."\r\n";
var_dump($value);
?>
2.3 运行结果
(int)5147486396的结果是5147486396,intval(5147486396)的结果是5147486396,filter_var(5147486396, FILTER_VALIDATE_INT)结果是5147486396。
3 结论
整型数的字长和平台有关,尽管通常最大值是大约二十亿(32 位有符号)。64 位平台下的最大值通常是大约 9E18。PHP 不支持无符号整数。Integer 值的字长可以用常量 PHP_INT_SIZE来表示,自 PHP 4.4.0 和 PHP 5.0.5后,最大值可以用常量 PHP_INT_MAX 来表示。
技术交流
CleverCode是一名架构师,技术交流,咨询问题,请加CleverCode创建的qq群(架构师俱乐部):517133582。加群和腾讯,阿里,百度,新浪等公司的架构师交流。【架构师俱乐部】宗旨:帮助你成长为架构师!