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)容進(jìn)行解碼時,可以將其解碼為數(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-07
php判斷頁面是否是微信打開的示例(微信打開網(wǎng)頁)
今天遇到一問題,讓一個頁面在微信上打開,PC上不能直接打開,下面是我使用的方法,現(xiàn)在分享給大家2014-04-04
PHP explode()函數(shù)的幾個應(yīng)用和implode()函數(shù)有什么區(qū)別
這篇文章主要介紹了PHP explode()函數(shù)的幾個應(yīng)用和implode()函數(shù)有什么區(qū)別,需要的朋友可以參考下2015-11-11

