json_encode()函數用法。
echo json_encode(array('a'=>'bbbb','c'=>'ddddd');
這樣就會生成一個標准的json格式的數據
代碼如下 復制代碼
<?php
//需要執行的SQL語句
//單條
$sql="select id,name from tbl_user where id=1";
//多條數據
//$sql="select id,name from tbl_user";
//調用conn.php文件進行數據庫操作
require('Conn.php');
//提示操作成功信息,注意:$result存在於conn.php文件中,被調用出來
if($result)
{
// $array=mysql_fetch_array($result,MYSQL_ASSOC);
/*數據集
$users=array();
$i=0;
while($row=mysql_fetch_array($result,MYSQL_ASSOC)){
echo $row['id'].'-----------'.$row['name'].'</br>';
$users[$i]=$row;
$i++;
}
echo json_encode(array('dataList'=>$users));
*/
/*單條數據*/
$row=mysql_fetch_row($result,MYSQL_ASSOC);
echo json_encode(array('jsonObj'=>$row));
}
mysql_free_result($result);
//釋放結果
mysql_close();
//關閉連接
?>
上面是數據庫生成json數據了
單條數據:{"jsonObj":{"id":"1","name":"lmw"}}
多條數據:{"dataList":[{"id":"1","name":"lmw"},{"id":"2","name":"xxj"},{"id":"3","name":"xxxj"}]}
現在很多情況下,我們需要程序返回一個Json格式的結果,比如:
代碼如下 復制代碼
{
"UserKeyGetResponse":
{"RequestName":"e99e6d63e8c712d7699f52978a","api_key_value":"41954dd9b1cb6a95802eab6810"},
"error_response":
{"code":"NO_ERROR(www.111cn.net)","msg":"獲取系統參數成功"}
}
可以將結果寫成這樣的數組形式:
$respon = array('UserKeyGetResponse' => array('RequestName' => $api_request_name, 'api_key_value' => $api_key_value),
'error_response' => array('code' => 'NO_ERROR', 'msg' => '獲取系統參數成功'));
代碼
代碼如下 復制代碼
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--;
}
g:
$error_respon = array('code' => 'ERROR_MSG_MISS', 'msg' => '消息不存在');
echo JSON($array);
結果為:
{"code":"ERROR_MSG_MISS","msg":"消息不存在"}
客戶端就可以解析這個結果了,當然錯誤碼要用數字代替。
這樣就好多了我們顯示的直接是中文了,當然顯示那個16進制的編碼也是沒有問題的哦。
from:http://www.111cn.net/phper/php/62544.htm
你是用jquery發送的ajax請求!可以使用$.each(msg,function(item,index){
//item代表每個對象!
//index代表索引
});
使用json_decode函數將數據解密。。PHP應用JSON的函數是:json_encode($PHPcode);
PHP解析JSON的函數是:json_decode($JSONcode);所以JSON的形式有多種,不同的形式在PHP解釋出來後的形式也是不同的。//形式1:完全是對象的形式,這種形式的數據在Javascript 中又叫相關數組,與一般數組不同的是, 它可以通過字符串作索引來訪問(用“[]”或“.” 來表示層級) $json='{"item1":{"item11":{"n":"chenling", "m":"llll"},"sex":"男","age":"25"},"item2": {"item21":"ling","sex":"女","age":"24"}}'; $J=json_decode($json); print_r($J); 看看php新手入門網的這篇關於php操作json數據的文章: www.phpnewer.com/index.php/Cjwt/detail/id/147