詳解PHP json_decode()函數(shù)的使用方法
json_decode() 可以對JSON字符串「解碼」,并轉(zhuǎn)換為PHP變量。
語法
mixed json_decoce( $json_str, assoc, depth, options )
參數(shù)
- $json_str :需要解碼的JSON字符串,只能處理UTF-8編碼的數(shù)據(jù)
- assoc :布爾類型,true返回數(shù)組,(默認(rèn))false返回對象
- depth :整數(shù)類型,遞歸的深度(默認(rèn)512層),最大 2147483647 層
- options :二進(jìn)制掩碼,目前只支持 JSON_BIGINT_AS_STRING
返回值
- 通過恰當(dāng)?shù)念愋停祷亟獯a后的數(shù)據(jù),默認(rèn)返回對象類型。
- JSON格式錯誤 或 超過遞歸解析深度 或 false 或 null,就返回null。
一、返回數(shù)組類型
json_decode() 默認(rèn)返回「對象」類型,如果想返回「數(shù)組」類型,就將 assoc 參數(shù)設(shè)置為true。 assoc 參數(shù)可省略,默認(rèn)為false。
實例:
var_dump(json_decode('{"key1":"value1","key2":"value2"}')); var_dump(json_decode('{"key1":"value1","key2":"value2"}', true));
輸出:
object(stdClass)#1 (2) {
["key1"]=>
string(6) "value1"
["key2"]=>
string(6) "value2"
}
array(2) {
["key1"]=>
string(6) "value1"
["key2"]=>
string(6) "value2"
}
options 參數(shù)設(shè)置為 JSON_OBJECT_AS_ARRAY 時,也可以轉(zhuǎn)換成「數(shù)組」類型。
實例:
var_dump(json_decode('{"key1":"value1","key2":"value2"}', JSON_OBJECT_AS_ARRAY));
輸出:
array(2) {
["key1"]=>
string(6) "value1"
["key2"]=>
string(6) "value2"
}
二、JSON的鍵和值必須用雙引號
「解析」的JSON字符串,最外側(cè)用單引號包裹,里面的鍵值對用「雙引號」包裹,才能正常解析,否則會返回null。
實例:
var_dump(json_decode('{"key1":"value1","key2":"value2"}')); var_dump(json_decode("{'key1':'value1','key2':'value2'}"));
輸出:
object(stdClass)#1 (2) {
["key1"]=>
string(6) "value1"
["key2"]=>
string(6) "value2"
}
NULL
這時,(PHP 7.3以上)可以設(shè)置參數(shù) options 為JSON_THROW_ON_ERROR,使其在解析錯誤時拋出異常,方便我們及時處理錯誤。
三、返回null問題
除了剛才提到的JSON字符串格式錯誤會返回null,還有其他的原因。
遇到返回null的問題時,可以在 json_decode() 后面,打印 json_last_error() 查看錯誤。
實例:
var_dump(json_decode("{'key1':'value1','key2':'value2'}")); echo json_last_error();
輸出:
NULL
4
json_last_error() 返回值解析:
- 0 = JSON_ERROR_NONE //沒有錯誤
- 1 = JSON_ERROR_DEPTH //超過最大堆棧深度
- 2 = JSON_ERROR_STATE_MISMATCH //無效或異常的json
- 3 = JSON_ERROR_CTRL_CHAR //控制字符錯誤,可能是編碼不對
- 4 = JSON_ERROR_SYNTAX //JSON字符串語法錯誤
- 5 = JSON_ERROR_UTF8 //異常的UTF-8字符,只能處理UTF8編碼的數(shù)據(jù)
四、大整數(shù)問題
options 參數(shù)設(shè)置為 JSON_BIGINT_AS_STRING,可以將超過PHP整型「最大值」的整數(shù)解析為字符串。
五、傳入非字符串類型
如果傳入的不是字符串類型,就不會解碼,或者說「無法解碼」:
- 數(shù)值型會原樣返回
- 運算符會運算后返回運算結(jié)果
- 布爾型(true返回1,false返回NULL)
- null會返回NULL
實例:
var_dump(json_decode(10)); var_dump(json_decode(10.11)); var_dump(json_decode(1*2)); var_dump(json_decode(true)); var_dump(json_decode(false)); var_dump(json_decode(null));
輸出:
int(10)
float(10.11)
int(2)
int(1)
NULL
NULL
六、強(qiáng)制類型轉(zhuǎn)換
解碼后進(jìn)行「強(qiáng)制類型轉(zhuǎn)換」
實例:
var_dump((array)json_decode(10)); var_dump((int)json_decode(false));
輸出:
array(1) {
[0]=>
int(10)
}
int(0)
到此這篇關(guān)于詳解PHP json_decode()函數(shù)的使用方法的文章就介紹到這了,更多相關(guān)PHP json_decode()函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PHP 自定義錯誤處理函數(shù)trigger_error()
trigger_error() 用于在用戶指定的條件下觸發(fā)一個錯誤消息。它與內(nèi)建的錯誤處理器一同使用,也可以與由 set_error_handler() 函數(shù)創(chuàng)建的用戶自定義函數(shù)使用2013-03-03php 中self,this的區(qū)別和操作方法實例分析
這篇文章主要介紹了php 中self,this的區(qū)別和操作方法,結(jié)合實例形式分析了PHP面向?qū)ο蟪绦蛟O(shè)計中self,this的功能、區(qū)別、使用方法與操作注意事項,需要的朋友可以參考下2019-11-11PHP一些常用的正則表達(dá)式字符的一些轉(zhuǎn)換
一些前臺的正則運行,你可以修改下成為php的2008-07-07php中g(shù)et_meta_tags()、CURL與user-agent用法分析
這篇文章主要介紹了php中g(shù)et_meta_tags()、CURL與user-agent用法,以實例形式較為詳細(xì)的分析了get_meta_tags()、CURL與user-agent使用時的注意事項與用法,具有一定的參考借鑒價值,需要的朋友可以參考下2014-12-12Function eregi is deprecated (解決方法)
本篇文章是對Function eregi() is deprecated錯誤的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06