程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php返回json數據函數實例,php返回json實例

php返回json數據函數實例,php返回json實例

編輯:關於PHP編程

php返回json數據函數實例,php返回json實例


本文實例講述了php返回json數據函數的用法,分享給大家供大家參考。具體方法如下:

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","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進制的編碼也是沒有問題的。

希望本文所述對大家的PHP程序設計有所幫助。


PHP 怎麼處理後台返回的json數據

你是用jquery發送的ajax請求!可以使用$.each(msg,function(item,index){
//item代表每個對象!
//index代表索引
});
 

php實現http抓取想要在本地實現sae裡fetchurl函數的功可以,返回json格式數據,指導

參考sae的分布式抓取http頁面的原理/

參考地址:e.sae.sina.com.cn/...pstore
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved