PHP使用JSON執行個體分析

來源:互聯網
上載者:User

   在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>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.