Zend Framework處理Json數(shù)據(jù)方法詳解
本文實例講述了Zend Framework處理Json數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
JSON分隔符及意義
{} 用于實現(xiàn)對象的包含,對象都包含在大括號中
, 逗號用于分隔對象的不同屬性,或者數(shù)組的元素
[] 用于存放數(shù)組,數(shù)組將存放在中括號中
: 用于表示鍵/值對的值,冒號前為鍵,冒號后為該鍵的值
JSON示例
{ "addressbook":{ "name":"Mary Lebow", "address":{ "street":"5 Main Street", "city":"San Diego,CA", "zip":91912 }, "phoneNumbers":[ "619 332-3452", "664 223-4667" ] } }
使用JSON
語法:$json = Zend_Json::encode($phpNative);
說明:其中,參數(shù)$phpNative為PHP常見的數(shù)據(jù)類型,可以是數(shù)組、對象或者其他類型的數(shù)據(jù)。
函數(shù)返回值$json為符合JSON格式的一個字符串。
示例:
<?php require_once("Zend/Json.php"); $temp = array( "a"=>0, "b"=>1, "c"=>array( "c-1"=>21, "c-2"=>22, "c-3"=>23, ), "d"=>3 ); $json = Zend_Json::encode($temp); echo "臨時數(shù)組內(nèi)容為:"; echo "<pre>"; print_r($temp); echo "</pre>"; echo "轉(zhuǎn)換為JSON格式內(nèi)容為:"; echo "<pre>"; print_r($json); echo "</pre>";
結(jié)果為:
臨時數(shù)組內(nèi)容為: Array ( [a] => 0 [b] => 1 [c] => Array ( [c-1] => 21 [c-2] => 22 [c-3] => 23 ) [d] => 3 ) 轉(zhuǎn)換為JSON格式內(nèi)容為: {"a":0,"b":1,"c":{"c-1":21,"c-2":22,"c-3":23},"d":3}
將JSON解碼為普通數(shù)據(jù)
語法:$phpNative = Zend_Json::decode($json);
示例:
<?php require_once("Zend/Json.php"); $json = "{ \"addressbook\":{ \"name\":\"zhangsan\", \"address\":{ \"street\":\"Chang an jie\", \"city\":\"BeiJing\", \"zip\":100001 }, \"phoneNumbers\":[ \"010-12345678\", \"010-11111111\" ] } }"; echo "解碼前為:"; echo "<pre>"; print_r($json); echo "</pre>"; $native = Zend_Json::decode($json); echo "解碼后為:"; echo "<pre>"; print_r($native); echo "</pre>";
輸出結(jié)果為:
解碼前為: { "addressbook":{ "name":"zhangsan", "address":{ "street":"Chang an jie", "city":"BeiJing", "zip":100001 }, "phoneNumbers":[ "010-12345678", "010-11111111" ] } } 解碼后為: Array ( [addressbook] => Array ( [name] => zhangsan [address] => Array ( [street] => Chang an jie [city] => BeiJing [zip] => 100001 ) [phoneNumbers] => Array ( [0] => 010-12345678 [1] => 010-11111111 ) ) )
說明:
在使用此方法對JSON內(nèi)容進行解碼時,可以將其解碼為數(shù)組,也可以將其解碼為對象。
具體有Zend_Json::decode()方法的第二個參數(shù)決定。
語法格式如下
phpNative=ZendJson::decode(phpNative=ZendJson::decode(json,Zend_Json::TYPE_OBJECT);
上個例子解碼為對象后的結(jié)果為
解碼后為: stdClass Object ( [addressbook] => stdClass Object ( [name] => zhangsan [address] => stdClass Object ( [street] => Chang an jie [city] => BeiJing [zip] => 100001 ) [phoneNumbers] => Array ( [0] => 010-12345678 [1] => 010-11111111 ) ) )
小結(jié):
Json的使用還是比較簡單的,在接口應(yīng)用上需要Json。它可以在不同的語言中共用??梢造`活的傳遞數(shù)據(jù)。作用與XML類似,但是比XML要節(jié)省帶寬。
PS:針對json的各種常用操作,還可參考使用本站相關(guān)json在線工具:
在線JSON代碼檢驗、檢驗、美化、格式化工具:
http://tools.jb51.net/code/json
JSON在線格式化工具:
http://tools.jb51.net/code/jsonformat
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat
在線json壓縮/轉(zhuǎn)義工具:
http://tools.jb51.net/code/json_yasuo_trans
C語言風(fēng)格/HTML/CSS/json代碼格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json
更多關(guān)于zend相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《Yii框架入門及常用技巧總結(jié)》、《ThinkPHP入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Zend Framework框架的PHP程序設(shè)計有所幫助。
相關(guān)文章
詳解Laravel5.6 Passport實現(xiàn)Api接口認(rèn)證
這篇文章主要介紹了詳解Laravel5.6 Passport實現(xiàn)Api接口認(rèn)證,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07php判斷頁面是否是微信打開的示例(微信打開網(wǎng)頁)
今天遇到一問題,讓一個頁面在微信上打開,PC上不能直接打開,下面是我使用的方法,現(xiàn)在分享給大家2014-04-04PHP explode()函數(shù)的幾個應(yīng)用和implode()函數(shù)有什么區(qū)別
這篇文章主要介紹了PHP explode()函數(shù)的幾個應(yīng)用和implode()函數(shù)有什么區(qū)別,需要的朋友可以參考下2015-11-11