php返回json数据函数例子
json_encode()函数用法。
echojson_encode(array('a'=>'bbbb','c'=>'ddddd');
这样就会生成一个标准的json格式的数据
代码如下复制代码
<?php
//需要执行的SQL语句
//单条
$sql="selectid,namefromtbl_userwhereid=1";
//多条数据
//$sql="selectid,namefromtbl_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++;
}
echojson_encode(array('dataList'=>$users));
*/
/*单条数据*/
$row=mysql_fetch_row($result,MYSQL_ASSOC);
echojson_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_ERRO(www.111cn.net)R","msg":"获取系统参数成功"}
}
可以将结果写成这样的数组形式:
$respon=array('UserKeyGetResponse'=>array('RequestName'=>$api_request_name,'api_key_value'=>$api_key_value),
'error_response'=>array('code'=>'NO_ERROR','msg'=>'获取系统参数成功'));
代码
代码如下复制代码
functionarrayRecursive(&$array,$function,$apply_to_keys_also=false)
{
static$recursive_counter=0;
if(++$recursive_counter>1000){
die('possibledeeprecursionattack');
}
foreach($arrayas$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'=>'消息不存在');
echoJSON($array);
结果为:
{"code":"ERROR_MSG_MISS","msg":"消息不存在"}
客户端就可以解析这个结果了,当然错误码要用数字代替。
这样就好多了我们显示的直接是中文了,当然显示那个16进制的编码也是没有问题的哦
from:http://www.111cn.net/phper/php/62544.htm