最模板 - 外贸网站建设,外贸网站模板

最模板

当前位置: 首页 > 建站教程 > php教程 >

php返回json数据函数例子

时间:2014-09-22 09:56来源:未知 作者:最模板zuimoban 点击:
json_encode()函数是一个在php中可以把数组转换成json格式的函数了,但json_encode函数对于英文是没有任何问题,如果碰到中文或编码有不致情况时会出现中文转换之后变空了,下面我就来从多

json_encode()函数是一个在php中可以把数组转换成json格式的函数了,但json_encode函数对于英文是没有任何问题,如果碰到中文或编码有不致情况时会出现中文转换之后变空了,下面我就来从多方面来介绍php返回json数据应用与一些使用转换时的问题解决办法.

json_encode()函数用法:echo json_encode(array('a'=>'bbbb','c'=>'ddddd');

这样就会生成一个标准的json格式的数据,代码如下:

  1. <?php 
  2.  
  3. //需要执行的SQL语句 
  4. //单条 
  5. $sql="select id,name from tbl_user where id=1"
  6. //多条数据 
  7. //$sql="select id,name from tbl_user"; 
  8.  
  9. //调用conn.php文件进行数据库操作  
  10. require('Conn.php'); 
  11.  
  12. //提示操作成功信息,注意:$result存在于conn.php文件中,被调用出来  
  13. if($result)  
  14.  
  15. // $array=mysql_fetch_array($result,MYSQL_ASSOC); 
  16.  
  17.    
  18.  /*数据集 
  19.  
  20.  $users=array(); 
  21.  $i=0; 
  22.  while($row=mysql_fetch_array($result,MYSQL_ASSOC)){ 
  23.  
  24.    echo $row['id'].'-----------'.$row['name'].'</br>'; 
  25.    $users[$i]=$row; 
  26.    $i++; 
  27.  
  28.  } 
  29.   echo json_encode(array('dataList'=>$users)); 
  30.  
  31.  */ 
  32.  
  33.  /*单条数据*/ 
  34.  
  35.  $row=mysql_fetch_row($result,MYSQL_ASSOC); 
  36.  
  37.  echo json_encode(array('jsonObj'=>$row)); 
  38.  
  39. mysql_free_result($result); 
  40. //释放结果 
  41. mysql_close(); 
  42. //关闭连接 
  43.  
  44. ?> 

上面是数据库生成json数据了.

单条数据:{"jsonObj":{"id":"1","name":"lmw"}}

多条数据:{"dataList":[{"id":"1","name":"lmw"},{"id":"2","name":"xxj"},{"id":"3","name":"xxxj"}]}

现在很多情况下,我们需要程序返回一个Json格式的结果,代码如下:

  1. "UserKeyGetResponse"
  2. {"RequestName":"e99e6d63e8c712d7699f52978a","api_key_value":"41954dd9b1cb6a95802eab6810"}, 
  3. "error_response"
  4. {"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' => '获取系统参数成功'));

PHP实例代码如下:

  1. function arrayRecursive(&$array$function$apply_to_keys_also = false) 
  2.     static $recursive_counter = 0; 
  3.     if (++$recursive_counter > 1000) { 
  4.         die('possible deep recursion attack'); 
  5.     } 
  6.     foreach ($array as $key => $value) { 
  7.         if (is_array($value)) { 
  8.             arrayRecursive($array[$key], $function$apply_to_keys_also); 
  9.         } else { 
  10.             $array[$key] = $function($value); 
  11.         } 
  12.         if ($apply_to_keys_also && is_string($key)) { 
  13.             $new_key = $function($key); 
  14.             if ($new_key != $key) { 
  15.                 $array[$new_key] = $array[$key]; 
  16.                 unset($array[$key]); 
  17.             } 
  18.         } 
  19.     } 
  20.     $recursive_counter--; 
  21. }//开源代码vcphp.com 
  22.  
  23. g: 
  24. $error_respon = array('code' => 'ERROR_MSG_MISS''msg' => '消息不存在'); 
  25. echo JSON($array); 

结果为:{"code":"ERROR_MSG_MISS","msg":"消息不存在"}

客户端就可以解析这个结果了,当然错误码要用数字代替,这样就好多了我们显示的直接是中文了,当然显示那个16进制的编码也是没有问题的.

(责任编辑:最模板)
------分隔线----------------------------
栏目列表
推荐内容