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数据 现在很多情况下,我们需要程序返回一个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":"消息不存在"} 客户端就可以解析这个结果了,当然错误码要用数字代替 。 希望本文所述对大家的PHP程序设计有所帮助 。 |