程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP使用JSON實例分析

PHP使用JSON實例分析

編輯:關於PHP編程

       在PHP編碼JSON(json_encode)

      PHP json_encode()函數用於在PHP JSON編碼。這個函數成功返回JSON表示的值,失敗則返回FALSE。

      語法:

      string json_encode ( $value [, $options = 0 ] )參數:

      value: 即將編碼的值,此函數只適用於UTF-8編碼的數據。

      options: 這個可選的值是一個位掩碼,由JSON_HEX_TAG JSON_HEX_QUOT,JSON_HEX_AMP,JSON_HEX_APOS,JSON_NUMERIC_CHECK,JSON_PRETTY_PRINT,JSON_UNESCAPED_SLASHES,JSON_FORCE_OBJECT

      例子

      下面的例子演示了如何用PHP數組轉換成JSON:

     代碼如下  

    <?php
       $arr = array('a' => 1, 'b' => 2, 'c' => 3, 'd' => 4, 'e' => 5);
       echo json_encode($arr);
    ?>

    在執行過程中,這將產生以下結果:

    {"a":1,"b":2,"c":3,"d":4,"e":5}

      下面的示例顯示如何將PHP對象可以轉換成JSON:

     代碼如下  

    <?php
       class Emp {
           public $name = "";
           public $hobbies  = "";
           public $birthdate = "";
       }
       $e = new Emp();
       $e->name = "sachin";
       $e->hobbies  = "sports";
       $e->birthdate = date('m/d/Y h:i:s a', "8/5/1974 12:20:03 p");
       $e->birthdate = date('m/d/Y h:i:s a', strtotime("8/5/1974 12:20:03"));

       echo json_encode($e);
    ?>

    在執行過程中,這將產生以下結果:

    {"name":"sachin","hobbies":"sports","birthdate":"08/05/1974 12:20:03 pm"}

      解碼JSON在PHP(json_decode)

      PHP json_decode()函數用於解碼JSON在PHP。這個函數返回值從json解碼成適當的 PHP類型。

      語法:

      mixed json_decode ($json [,$assoc = false [, $depth = 512 [, $options = 0 ]]])參數:

      json_string: 它必須是UTF-8編碼的數據編碼的字符串

      assoc: 這是一個布爾類型參數設置為TRUE時,返回的對象將被轉換成關聯數組

      depth: 它是一個整數類型的參數,它指定遞歸深度

      options: 它是一個整數類型的位掩碼JSON解碼,支持JSON_BIGINT_AS_STRING

      例子

      下面的示例顯示了如何可以使用PHP來解碼JSON對象:

     代碼如下  

    <?php
       $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';

       var_dump(json_decode($json));
       var_dump(json_decode($json, true));
    ?>

    在執行過程中,這將產生以下結果:

    object(stdClass)#1 (5) {
        ["a"] => int(1)
        ["b"] => int(2)
        ["c"] => int(3)
        ["d"] => int(4)
        ["e"] => int(5)
    }

    array(5) {
        ["a"] => int(1)
        ["b"] => int(2)
        ["c"] => int(3)
        ["d"] => int(4)
        ["e"] => int(5)
    }

      假如我們獲取的JSON數據如下:(可以使用curl、fsockopen等方式獲取)

     代碼如下  

    {
     "translation":["Hello world"],
     "query":"你好世界",
     "errorCode":0,
     "web":[
      {
       "value":["hello world"],
       "key":"你好世界"
      },
      {
       "value":["Hello World"],
       "key":"世界你好"
      }
     ]
    }

    用json_decode函數返回array的方式得到:

    Array
    (
     [translation] => Array
      (
       [0] => Hello world
      )
     [query] => 你好世界
     [errorCode] => 0
     [web] => Array
      (
       [0] => Array
        (
         [value] => Array
          (
           [0] => hello world
          )
         [key] => 你好世界
        )
       [1] => Array
        (
         [value] => Array
          (
           [0] => Hello World
          )
         [key] => 世界你好
        )
      )
    )

      我們在PHP語言中可以用以下方法取得我們想要的值:

     代碼如下  

    <?php
    /*----------------------------------
    $data = '
    {
     "translation":["Hello world"],
     "query":"你好世界",
     "errorCode":0,
     "web":[
      {
       "value":["hello world"],
       "key":"你好世界"
      },
      {
       "value":["Hello World"],
       "key":"世界你好"
      }
     ]
    }
    ';
    -------------------------------------*/
    $data = <<<STR
    {
     "translation":["Hello world"],
     "query":"你好世界",
     "errorCode":0,
     "web":[
      {
       "value":["hello world"],
       "key":"你好世界"
      },
      {
       "value":["Hello World"],
       "key":"世界你好"
      }
     ]
    }
    STR;
    $jsondata=json_decode($data,true);
    header("Content-Type: text/html; charset=UTF-8");
    //print_r($jsondata);
    echo "<br />".$jsondata['translation'][0]; //Hello world
    echo "<br />".$jsondata['query']; //你好世界
    echo "<br />".$jsondata['web'][0]['value'][0]; //hello world
    echo "<br />".$jsondata['web'][1]['key']; //世界你好
    ?>

      例,結合數據庫操作

     代碼如下  

    <?php 
    include './include/conn.php';  //數據庫鏈接文件
    $sql_notice = mysql_query('SELECT * FROM gg_notice where enable = "1" limit 0,10');
    $notice = mysql_fetch_array($sql_notice, MYSQL_ASSOC);
    print_r ($notice);
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title>第一php網提供的教程--將數據庫讀取的數據生成json格式</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <!-- <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"/></script> -->
    <script language=javascript>
    </script>
    </head>
    <body>
    <pre>
    <h1>請注意兩種方法生成的對象數組在結構上的區別</h1>
    <?php
    echo '<h1>法一</h1>';
    //假設以下數組是根據我們從數據庫讀取的數據生成的
    $jarr=array('total'=>239,'row'=>array(
               array('code'=>'001','name'=>'中國www.111cn.net','addr'=>'Address 11','col4'=>'col4 data'),
               array('code'=>'002','name'=>'Name 2','addr'=>'Address 12','col4'=>'col4 data'),
                                         )
               );
    //法一:
    $jobj=new stdclass();//實例化stdclass,這是php內置的空類,可以用來傳遞數據,由於json_decode後的數據是以對象數組的形式存放的,
    //所以我們生成的時候也要把數據存儲在對象中
    foreach($jarr as $key=>$value){
    $jobj->$key=$value;
    }
    print_r($jobj);//打印傳遞屬性後的對象
    echo '使用$jobj->row[0]['code']輸出數組元素:'.$jobj->row[0]['code'].'<br>';
    echo '編碼後的json字符串:'.json_encode($jobj).'<br>';//打印編碼後的json字符串


    echo '<hr>';
    //法二:
    echo '<h1>法二</h1>';
    echo '編碼後的json字符串:';
    echo $str=json_encode($jarr);//將數組進行json編碼
    echo '<br>';
    $arr=json_decode($str);//再進行json解碼
    print_r($arr);//打印解碼後的數組,數據存儲在對象數組中
    echo '使用$arr->row[0]->code輸出數組元素:'.$arr->row[0]->code;

    ?>

    </body>
    </html>

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved