在現(xiàn)代開發(fā)中,數(shù)據(jù)接口的傳遞方式多種多樣,比較簡潔而流行的一種方式是以JSON格式傳遞。而在使用PHP語言進行開發(fā)時,PHP可與JSON相互轉(zhuǎn)換,十分方便。本文將講述JSON的轉(zhuǎn)換過程,并使用實例說明其中的細節(jié)與注意點。
JSON的轉(zhuǎn)換包含兩種類型:將JSON字符串轉(zhuǎn)換為PHP數(shù)組、對象,以及將PHP數(shù)組或?qū)ο筠D(zhuǎn)換為JSON格式字符串。這兩種方式對于PHP接收與發(fā)送JSON格式的數(shù)據(jù)都是必不可少的。
首先從JSON格式字符串轉(zhuǎn)換為PHP數(shù)組開始。在PHP中,可以使用json_decode函數(shù)將JSON格式字符串解碼為PHP數(shù)組或?qū)ο蟆.斎?,在一些情況下需要JSON格式的字符串解碼為object對象。我們可通過第二個參數(shù)控制解碼后返回數(shù)據(jù)的類型。默認值為false,表示返回數(shù)組;在需要返回object對象時,我們可以將其設(shè)置為true。
舉例來看,下面的JSON格式字符串:
{ "name":"Luffy", "id":1, "abilities":["Rubber body","King's Haki"] }使用json_decode函數(shù)嵌套print_r函數(shù)將其轉(zhuǎn)換為PHP數(shù)組并輸出:
$json = '{ "name":"Luffy", "id":1, "abilities":["Rubber body","King\'s Haki"] }'; $array = json_decode($json, true); print_r($array); 輸出: Array ( [name] =>Luffy [id] =>1 [abilities] =>Array ( [0] =>Rubber body [1] =>King's Haki ) )可以看到,使用json_decode函數(shù)將JSON格式字符串轉(zhuǎn)換為PHP數(shù)組或?qū)ο?,格式非常簡潔。不過,需要注意的是:JSON規(guī)范要求字符串中的引號必須為雙引號,因此在編寫JSON格式字符串時應(yīng)注意與PHP代碼中使用的單雙引號區(qū)分。 接下來,我們了解將PHP數(shù)組或?qū)ο筠D(zhuǎn)換為JSON格式字符串。也很簡單,使用json_encode函數(shù)即可。當然,json_encode函數(shù)也可以嵌套print_r函數(shù)以查看返回字符串:
$array = array( 'name' =>'Luffy', 'id' =>1, 'abilities' =>array( 'Rubber body', 'King\'s Haki' ) ); $json = json_encode($array); print_r($json); 輸出: {"name":"Luffy","id":1,"abilities":["Rubber body","King's Haki"]}需要注意:JSON規(guī)范要求不允許使用單引號,字符串只能使用雙引號,如果數(shù)組中的字符串中已經(jīng)使用了雙引號,那么我們需要在其前面加上反斜杠(\)進行轉(zhuǎn)義。 在實際開發(fā)中,我們常常遇到多維數(shù)組的情況,這時候就會見到j(luò)son_decode函數(shù)嵌套使用的情況,以更好地處理數(shù)據(jù)。 例如,下面的JSON格式字符串:
{ "title": "Luffy's family", "members": [ { "name":"Monkey D. Dragon", "age": 63, "relation": "father" }, { "name": "Monkey D. Garp", "age": 80, "relation": "grandfather" } ] }嵌套使用json_decode:
$json = '{ "title": "Luffy\'s family", "members": [ { "name":"Monkey D. Dragon", "age": 63, "relation": "father" }, { "name": "Monkey D. Garp", "age": 80, "relation": "grandfather" } ] }'; $array = json_decode($json, true); foreach($array['members'] as $member){ echo 'Name:'.$member['name'].' Age:'.$member['age'].' Relation:'.$member['relation'].'對于數(shù)據(jù)量較大的數(shù)組或?qū)ο螅谵D(zhuǎn)換時需要一些額外的設(shè)置。例如,需要在PHP 5.4及以上版本開啟options參數(shù),設(shè)置JSON編碼時的非數(shù)組或?qū)ο髤?shù)的處理方式(默認是轉(zhuǎn)換為空字符串)。在解碼時,我們可設(shè)置第三個參數(shù)為深度,限制解析的深度及循環(huán)引用的處理方式。這些細節(jié)因具體情況而異,在珂以開發(fā)過程中需要注意細節(jié)。 本文就是介紹了JSON與PHP的兩種相互轉(zhuǎn)換方式,并結(jié)合代碼實例詳細說明了這個過程所需要注意的細節(jié)與常見問題。通過掌握這些知識,開發(fā)者們可以更加順利地進行JSON格式字符串與PHP數(shù)組或?qū)ο蟮慕换?,從而更好地完成項目開發(fā)。
'; } 輸出: Name:Monkey D. Dragon Age:63 Relation:father Name:Monkey D. Garp Age:80 Relation:grandfather