php返回json数据简单实例

jerry PHP 2015年08月30日 收藏

php返回json数据简单实例
include/conn.php为数据库链接文件,不会的网上搜索

  1. <?php 
  2. include './include/conn.php';  //数据库链接文件
  3. $sql_notice = mysql_query('SELECT * FROM gg_notice where enable = "1" limit 0,10');
  4. $notice = mysql_fetch_array($sql_notice, MYSQL_ASSOC);
  5. print_r ($notice);
  6. ?>
  7. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  8. <html xmlns="http://www.w3.org/1999/xhtml">
  9. <head>
  10. <title>第一php网提供的教程--将数据库读取的数据生成json格式</title>
  11. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  12. <!-- <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"/></script> -->
  13. <script language=javascript>
  14. </script>
  15. </head>
  16. <body>
  17. <h1>请注意两种方法生成的对象数组在结构上的区别</h1>
  18. <?php
  19. echo '<h1>法一</h1>';
  20. //假设以下数组是根据我们从数据库读取的数据生成的
  21. $jarr=array('total'=>239,'row'=>array(
  22.            array('code'=>'001','name'=>'中国','addr'=>'Address 11','col4'=>'col4 data'),
  23.            array('code'=>'002','name'=>'Name 2','addr'=>'Address 12','col4'=>'col4 data'),
  24.                                      )
  25.            );
  26. //法一:
  27. $jobj=new stdclass();//实例化stdclass,这是php内置的空类,可以用来传递数据,由于json_decode后的数据是以对象数组的形式存放的,
  28. //所以我们生成的时候也要把数据存储在对象中
  29. foreach($jarr as $key=>$value){
  30. $jobj->$key=$value;
  31. }
  32. print_r($jobj);//打印传递属性后的对象
  33. echo '使用$jobj->row[0][\'code\']输出数组元素:'.$jobj->row[0]['code'].'<br>';
  34. echo '编码后的json字符串:'.json_encode($jobj).'<br>';//打印编码后的json字符串
  35. echo '<hr>';
  36. //法二:
  37. echo '<h1>法二</h1>';
  38. echo '编码后的json字符串:';
  39. echo $str=json_encode($jarr);//将数组进行json编码
  40. echo '<br>';
  41. $arr=json_decode($str);//再进行json解码
  42. print_r($arr);//打印解码后的数组,数据存储在对象数组中
  43. echo '使用$arr->row[0]->code输出数组元素:'.$arr->row[0]->code;
  44. ?> 
  45. </body>
  46. </html>