php将查询数据返回json格式数据的例子

发布时间:2019-12-21编辑:脚本学堂
php如何将数据库查询结果返回为json格式数据,一个php返回json数据的函数,并介绍了正确显示中文json数据的方法。

一、php实现查询数据库返回json数据。

例一:
 

复制代码 代码示例:
// 设置返回json格式数据
header('content-type:application/json;charset=utf8');
 
//连接数据库
$link = mysql_connect("localhost", "root", "root") or die("Unable to connect to the MySQL!");
 
mysql_query("SET NAMES 'UTF8'");
 
mysql_select_db("jilinwula", $link) or die("Unable to connect to the MySQL!");
 
// 获取分页参数
$page = 0 ;
$pageSize = 3;
 
if(!is_null($_GET["page"])) {
$page = $_GET["page"];
}
 
if(!is_null($_GET["pageSize"])) {
$pageSize = $_GET["pageSize"];
}
 
// 查询数据到数组中
$result = mysql_query("select username,password from userinfo limit " . $page . ", ". $pageSize ."");
 
$results = array();
while ($row = mysql_fetch_assoc($result)) {
$results[] = $row;
}
 
// 将数组转成json格式
echo json_encode($results);
 
// 关闭连接
mysql_free_result($result);
 
mysql_close($link);

例二:
 

复制代码 代码示例:
<?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();
//关闭连接
 
?>

二、php返回json数据函数

php返回json数据函数json_encode()函数用法。

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进制的编码也是没有问题的。