-
json_decode 整型溢出解决方法
这个有点像mysql int类型超过了就溢出,而我们只要用bigint就可以了,那么因为php中int数据范围的问题,所以就也有可能出现这类问题。
编码过程中遇到个错误,就是在处理json时,数值较大的int值在解码后数据被损坏,比如:
- $array = array(
- "id1" => 2147483647,
- "id2" => 2147483648
- );
- $json = json_encode($array);
- $out = json_decode($json, true);
- var_dump($out);
- 理论上应该看到:
- array(2) {
- ["id1"]=>int(2147483647)
- ["id2"]=>int(2147483648)
- }
- 但实际在我的电脑上却得到:
- 代码如下 复制代码
- array(2) {
- ["id1"]=>int(2147483647)
- ["id2"]=>int(-2147483646)
- }
这是由PHP整数值范围决定的,而这个范围依赖于操作系统。在32位操作系统中,PHP的整数最大值是2147483647,你可以通过输出PHP_INT_MAX看到。
一般情况下,你赋值一个很大的数,PHP会自动判定这个数值的范围并自动转换类型,如:
- $large_number = 2147483647;
- var_dump($large_number); // int(2147483647)
- $large_number = 2147483648;
- var_dump($large_number); // float(2147483648)
- $million = 1000000;
- $large_number = 50000 * $million;
- var_dump($large_number); // float(50000000000)
但是在json_decode方法中没有进行这种检测,这是PHP(旧版本)的bug,在5.3以后的版本,就不存在这个问题了。
如果你不想更新你的PHP,那还有个办法,就是将数字转为字符串。还是以上面的代码为例:
- $array = array(
- "id1" => 2147483647,
- "id2" => 2147483648
- );
- $json = json_encode($array);
- $json = preg_replace('/("idd":)(d{9,})/i', '${1}"${2}"', $json);
- $out = json_decode($json, true);
- var_dump($out);
当然,这个怎么替换是按需而定的,而且需要比较细致的测试。
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式