從5.2版本開始,PHP原生提供json_encode()和json_decode()函數,前者用于編碼,后者用于解碼。
一、json_encode()
該函數主要用來將數組和對象,轉換為json格式。先看一個數組轉換的例子:
1 | $arr = array ( 'a' =>1, 'b' =>2, 'c' =>3, 'd' =>4, 'e' =>5); |
結果為:{"a":1,"b":2,"c":3,"d":4,"e":5}
再看一個對象轉換的例子:
1 | $obj ->body = 'another post' ; |
4 | $obj ->favorite_count = 1; |
結果為:{"body":"another post","id":21,"approved":true,"favorite_count":1,"status":null}
由于json只接受utf-8編碼的字符,所以json_encode()的參數必須是utf-8編碼,否則會得到空字符或者null。當中文使用GB2312編碼,或者外文使用ISO-8859-1編碼的時候,這一點要特別注意。
二、索引數組和關聯數組
PHP支持兩種數組,一種是只保存"值"(value)的索引數組(indexed array),另一種是保存"名值對"(name/value)的關聯數組(associative array)。
由于javascript不支持關聯數組,所以json_encode()只將索引數組(indexed array)轉為數組格式,而將關聯數組(associative array)轉為對象格式。
比如,現在有一個索引數組
1 | $arr = array ( 'one' , 'two' , 'three' ); |
1 | 結果為:[ "one" , "two" , "three" ] |
如果將它改為關聯數組:
1 | $arr = Array( '1' => 'one' , '2' => 'two' , '3' => 'three' ); |
結果就變了:{"1":"one","2":"two","3":"three"}
注意,數據格式從"[]"(數組)變成了"{}"(對象)。
如果你需要將"索引數組"強制轉化成"對象",可以這樣寫:
1 | json_encode( (object) $arr ); |
或者:
1 | json_encode ( $arr , JSON_FORCE_OBJECT ); |
三、類(class)的轉換
下面是一個PHP的類:
2 | const ERROR_CODE = '404' ; |
3 | public $public_ex = 'this is public' ; |
4 | private $private_ex = 'this is private!' ; |
5 | protected $protected_ex = 'this should be protected' ; |
6 | public function getErrorCode() { |
7 | return self::ERROR_CODE; |
現在,對這個類的實例進行json轉換:
2 | $foo_json = json_encode( $foo ); |
輸出結果是:{"public_ex":"this is public"}
可以看到,除了公開變量(public),其他東西(常量、私有變量、方法等等)都遺失了。
四、json_decode()
該函數用于將json文本轉換為相應的PHP數據結構。下面是一個例子:
1 | $json = '{"foo": 12345}' ; |
2 | $obj = json_decode( $json ); |
通常情況下,json_decode()總是返回一個PHP對象,而不是數組。比如:
1 | $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}' ; |
2 | var_dump(json_decode( $json )); |
結果就是生成一個PHP對象:
如果想要強制生成PHP關聯數組,json_decode()需要加一個參數true:
1 | $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}' ; |
2 | var_dump(json_decode( $json ,true)); |
結果就生成了一個關聯數組:
五、json_decode()的常見錯誤
下面三種json寫法都是錯的,你能看出錯在哪里嗎?
1 | $bad_json = "{ 'bar': 'baz' }" ; |
2 | $bad_json = '{ bar: "baz" }' ; |
3 | $bad_json = '{ "bar": "baz", }' ; |
對這三個字符串執行json_decode()都將返回null,并且報錯。
第一個的錯誤是,json的分隔符(delimiter)只允許使用雙引號,不能使用單引號。
第二個的錯誤是,json名值對的"名"(冒號左邊的部分),任何情況下都必須使用雙引號。
第三個的錯誤是,最后一個值之后不能添加逗號(trailing comma)。
另外,json只能用來表示對象(object)和數組(array),如果對一個字符串或數值使用json_decode(),將會返回null。
1 | var_dump(json_decode( "Hello World" )); |