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