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(514748639