本文实例讲述了Zend Framework处理Json数据的方法。分享给大家供大家参考,具体如下:
JSON分隔符及意义
{} 用于实现对象的包含,对象都包含在大括号中
, 逗号用于分隔对象的不同属性,或者数组的元素
[] 用于存放数组,数组将存放在中括号中
: 用于表示键/值对的值,冒号前为键,冒号后为该键的值
JSON示例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
{
"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);
说明:其中,参数$phpNative为PHP常见的数据类型,可以是数组、对象或者其他类型的数据。
函数返回值$json为符合JSON格式的一个字符串。
示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
<?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 "临时数组内容为:" ;
echo "<pre>" ;
print_r( $temp );
echo "</pre>" ;
echo "转换为JSON格式内容为:" ;
echo "<pre>" ;
print_r( $json );
echo "</pre>" ;
|
结果为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
临时数组内容为:
Array
(
[a] => 0
[b] => 1
[c] => Array
(
[c-1] => 21
[c-2] => 22
[c-3] => 23
)
[d] => 3
)
转换为JSON格式内容为:
{"a":0,"b":1,"c":{"c-1":21,"c-2":22,"c-3":23},"d":3}
|
将JSON解码为普通数据
语法:$phpNative = Zend_Json::decode($json);
示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
<?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>" ;
|
输出结果为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
解码前为:
{
"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内容进行解码时,可以将其解码为数组,也可以将其解码为对象。
具体有Zend_Json::decode()方法的第二个参数决定。
语法格式如下
phpNative=ZendJson::decode(phpNative=ZendJson::decode(json,Zend_Json::TYPE_OBJECT);
上个例子解码为对象后的结果为
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
解码后为:
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
)
)
)
|
小结:
Json的使用还是比较简单的,在接口应用上需要Json。它可以在不同的语言*用。可以灵活的传递数据。作用与XML类似,但是比XML要节省带宽。
希望本文所述对大家基于Zend Framework框架的PHP程序设计有所帮助。