欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Zend Framework處理Json數(shù)據(jù)方法詳解

 更新時間:2016年12月09日 15:29:16   作者:牛逼的霍嘯林  
這篇文章主要介紹了Zend Framework處理Json數(shù)據(jù)方法,結(jié)合實例形式分析了zend framework針對json相關(guān)操作類的使用方法,需要的朋友可以參考下

本文實例講述了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)文章

最新評論