Chinaunix首页 | 论坛 | 博客
  • 博客访问: 50754
  • 博文数量: 20
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 255
  • 用 户 组: 普通用户
  • 注册时间: 2014-09-19 14:01
文章分类

全部博文(20)

文章存档

2014年(20)

我的朋友

分类: PHP

2014-10-08 21:07:02

json_encode()函数用法。


echo json_encode(array('a'=>'bbbb','c'=>'ddddd');


这样就会生成一个标准的json格式的数据


 代码如下 复制代码 


//需要执行的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'].'
';
   $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_ERRO()R","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进制的编码也是没有问题的哦
from:
阅读(618) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~