unserialize的整型溢出错误

同事使用wnmp环境做本地开发,但是当从linux测试服务器中导出数据在本地调试的时候,发现使用unserialize函数解析序列化数据时报错:

Notice: unserialize() [<a href='function.unserialize'>function.unserialize</a>]: Error at offset 741 of 1242 bytes in ……


经过调试之后我发现是因为反序列化时整形数据溢出导致的,我建议其暂时使用如下函数得到能正常使用的返回值:

function _unserialize($string)
{
    return unserialize(preg_replace('/i:(\d{12});/i', 's:12:"$1";', preg_replace('/i:(\d{11});/i', 's:11:"$1";', $string)));
}


根据PHP官方手册所说,整型数的字长和平台有关,尽管通常最大值是大约二十亿(32 位有符号)。64 位平台下的最大值通常是大约 9E18。PHP 不支持无符号整数。Integer 值的字长可以用常量 PHP_INT_SIZE来表示,自 PHP 4.4.0 和 PHP 5.0.5后,最大值可以用常量 PHP_INT_MAX 来表示。


但是,当我们在Windows下使用64位PHP的时候,PHP_INT_SIZE为4,PHP_INT_MAX为2^31-1。与之相反的是,如果在Linux下使用64位PHP,PHP_INT_SIZE为8,PHP_INT_MAX为2^63-1。PHP Bugs官方也有这么一条BUG报告:https://bugs.php.net/bug.php?id=64863


因此,建议尽量使用和生产环境相同的服务器环境来做本地开发,才能避免类似的非功能性错误。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值