這個有點像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);
當然,這個怎么替換是按需而定的,而且需要比較細致的測試。
新聞熱點
疑難解答