PHP中JSON的應用

  文章來源:PHP開發學習門戶javascript

  地址:  http://www.phpthinking.com/archives/513php


    互聯網的今天,AJAX已經不是什麼陌生的詞彙了。提及AJAX,可能會立刻想原由RSS而興起的XML。html

不能否認,XML是很是不錯的數據存儲方式,但是其靈活偏偏形成了其解析的困難。固然,這裏所指的困難,是相對於本文的主角--JSON而言。java

    JSON爲什麼物?我就不反覆概念了。通俗的說,它是一種數據的存儲格式,就像PHP序列化後的字符串同樣。它是一種數據描寫敘述。比方咱們將一個數組序列化後存放,就可以很是easy的反序列化後應用。JSON也是如此,僅僅只是他搭建的是clientJavascript和服務端PHP的交互橋樑。咱們用PHP生成JSON後的字符串。而後把這個字符串傳給前臺Javascript,Javascirpt就可以很是easy的將其反JSON而後應用。說通俗點,它真的很是像數組。 言歸正傳。怎樣使用JSON。PHP5.2開始內置了JSON的支持。固然,假設低於這個版本號的話,那麼市面上有很是多PHP版本號的實現。隨便下一個用就OK啦。現在主要是說說PHP內置支持的JSON。很是簡單,兩個函數:json_encode和json_decode(跟序列化很是像啦)。一個編碼。一個解碼。先看看編碼的使用:

web

<?

php     $arr = array(         'name' => '陳毅鑫',         'nick' => '深空',         'contact' => array(             'email' => 'shenkong at qq dot com',             'website' => 'http://www.chinaz.com',         )     );     $json_string = json_encode($arr);     echo $json_string;     ?> 

很是easy的將一個數組JSON了。需要指出的是,在非UTF-8編碼下,中文字符將不可被encode。結果會出來空值,因此。假設你使用gb2312編寫PHP代碼,那麼就需要將包括中文的內容使用iconv或者mb轉爲UTF-8再進行json_encode,上面輸出結果例如如下:json

{"name":"\u9648\u6bc5\u946b","nick":"\u6df1\u7a7a""contact":{"email":"shenkong at qq dot com","website":"http:\/\/www.chinaz.com"}} 

我都說了和序列化很是像,你還不信。編碼後就要解碼,PHP提供了對應的函數json_decode。json_decode運行後,將會獲得一個對象,操做例如如下:跨域

數組

<?

php     $arr = array(         'name' => '陳毅鑫',         'nick' => '深空',         'contact' => array(             'email' => 'shenkong at qq dot com',             'website' => 'http://www.chinaz.com',         )     );     $json_string = json_encode($arr);     $obj = json_decode($json_string);     print_r($obj);     ?> 

訪問對象內的屬性會吧?$obj->name。這樣子的。固然。也可以把它轉位數組,方便調用啦:緩存

$json_string = json_encode($arr);    
$obj = json_decode($json_string);    
$arr = array($obj);    
print_r($arr);  

PHP轉來轉去的用途不是特別大。除了緩存生成。感受還不如直接存數組呢。只是,當你和前臺交互的時候,它的做用就出來咯,如下看看我怎麼用Javascript來使用這段字符:安全

<script type="text/javascript">  
var arr = {"name":"\u9648\u6bc5\u946b","nick":"\u6df1\u7a7a""contact":{"email":"shenkong at qq dot com","website":"http:\/\/www.chinaz.com"}};    
alert(arr.name)    
</script>  

上面中。直接將這個字符串賦給一個變量。它就變成一個Javascript數組了(專業化術語應該不叫數組。只是由於PHP的習慣問題,我就一直叫數組好了,方便理解)。

這樣。可以很是方便的對arr進行遍歷或者隨意作你想作的事情了。寫到這裏。好像都沒提到AJAX哦?是哦,聯想一下。假設服務端返回的responseText用JSON過的字符串取代XML的話,前臺Javascript處理起來是否是很是方便呢?狗皮膏藥就是這樣用的。 事實上寫到這裏。除了數據的存儲格式不太同樣外,JSON和XML也沒什麼太大差異哦,只是如下我說的一點。

儘管和XML沒多大關係。只是。可以說明JSON更大範圍的應用,那就是。跨域的數據調用。由於安全性問題,AJAX不支持跨域調用,這樣要調用不一樣域名下的數據。很是麻煩哦,儘管有解決方式(stone在他的講座上提到過了代理啊什麼的儘管聽不懂但是知道能解決)。

我寫兩個文件,足以展現跨域調用了。 主調文件index.html

<script type="text/javascript">   
function getProfile(str) {    
    var arr = str;    
    document.getElementById('nick').innerHTML = arr.nick;    
}    
</script>   
<body><div id="nick"></div></body>   
<script type="text/javascript" src="http://www.openphp.cn/demo/profile.php"></script>  

被調文件profile.php

<?php    
$arr = array(    
    'name' => '陳毅鑫',    
    'nick' => '深空',    
    'contact' => array(    
        'email' => 'shenkong at qq dot com',    
        'website' => 'http://www.chinaz.com',    
    )    
);    
$json_string = json_encode($arr);    
echo "getProfile($json_string)";    
?> 

很是顯然,當index.html調用profile.php時,JSON字符串生成。並做爲參數傳入getProfile,而後將暱稱插入到div中,這樣一次跨域數據交互就完畢了,是否是特別簡單。既然JSON這麼簡單易用而且好用,還等什麼呢?

相關文章
相關標籤/搜索