我寫這套系列文章的目的,是幫助那些做php+android的程序員。因為,這方面的資料有點少,希望我這個菜鳥的文章能夠幫到大家。
工具/原料
Macromedia Dreamweaver 8
mysql數據庫,php語言
一、前言
為什麼在教程的第一篇文章,我就選擇講解JSON亂碼的問題呢?因為Android本身是無法直接訪問mysql數據庫的,需要藉助於PHP網頁才能完成對mysql數據庫的操作。而PHP和Android之間交換數據需要使用JSON格式。
二、什麼是json
21世紀初,Douglas Crockford尋找一種簡便的數據交換格式,能夠在服務器之間交換數據。當時通用的數據交換語言是XML,但是Douglas Crockford覺得XML的生成和解析都太麻煩,所以他提出了一種簡化格式,也就是Json。
Json的規格非常簡單,只用一個頁面幾百個字就能說清楚,而且Douglas Crockford聲稱這個規格永遠不必升級,因為該規定的都規定了。
1) 並列的數據之間用逗號(", ")分隔。
2) 映射用冒號(": ")表示。
3) 並列數據的集合(數組)用方括號("[]")表示。
4) 映射的集合(對象)用大括號("{}")表示。
上面四條規則,就是Json格式的所有內容。
比如,下面這句話:
"北京市的面積為16800平方公里,常住人口1600萬人。上海市的面積為6400平方公里,常住人口1800萬。
寫成json格式就是這樣:
[ {"城市":"北京","面積":16800,"人口":1600}, {"城市":"上海","面積":6400,"人口":1800}]
如果事先知道數據的結構,上面的寫法還可以進一步簡化:
[ ["北京",16800,1600], ["上海",6400,1800]]
由此可以看到,json非常易學易用。所以,在短短几年中,它就取代xml,成為了互聯網上最受歡迎的數據交換格式。
三、PHP中JSON中文亂碼
在 php 中使用 json_encode() 內置函數(php > 5.2)可以使用得 php 中數據可以與其它語言很好的傳遞並且使用它。這個函數的功能是將數值轉換成json數據存儲格式。
$arr = array( 'Name'=>'希亞','Age'=>20);
$jsonencode = json_encode($arr);
echo $jsonencode;
?>
程序運行結果如下:
數組中的中文在json_encode之後出現了\u5e0c\u4e9a之類的亂碼。
解決方法是用urlencode()函數處理以下,在json_encode之前,把所有數組內所有內容都用urlencode()處理一下,然用json_encode()轉換成json字符串,最後再用urldecode()將編碼過的中文轉回來。
/**************************************************************
*
*
使用特定function對數組中所有元素做處理
* @param string &$array 要處理的字符串
* @param string $function 要執行的函數
* @return boolean $apply_to_keys_also 是否也應用到key上
* @access public
*
*************************************************************/
function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
{
static $recursive_counter = 0;
if (++$recursive_counter > 1000)
{
die('possible deep recursion attack');
}
foreach ($array as $key => $value)
{
if (is_array($value))
{
arrayRecursive($array[$key], $function, $apply_to_keys_also);
}
else
{
$array[$key] = $function($value);
}
if ($apply_to_keys_also && is_string($key))
{
$new_key = $function($key);
if ($new_key != $key)
{
$array[$new_key] = $array[$key];
unset($array[$key]);
}
}
}
$recursive_counter--;
}
/**************************************************************
*
* 將數組轉換為JSON字符串(兼容中文)
* @param array $array 要轉換的數組
* @return string 轉換得到的json字符串
* @access public
*
*************************************************************/
function JSON($array)
{
arrayRecursive($array, 'urlencode', true);
$json = json_encode($array);
return urldecode($json);
}
$array = array ( 'Name'=>'希亞','Age'=>20);
echo JSON($array);
?>
這次代碼成功運行了
注意事項
本文並非原創,特此聲明!