成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在PHP語言中使用JSON

開發(fā) 后端
JSON是一種輕量級的數(shù)據(jù)交換格式。易于人閱讀和編寫,同時也易于機器解析和生成。它基于JavaScript的一個子集。JSON采用完全獨立于語言的文本格式,但是也使用了類似于C語言家族的習(xí)慣(包括C, C++, C#, Java, JavaScript, Perl, Python等)。這些特性使JSON成為理想的數(shù)據(jù)交換語言。

目前,JSON已經(jīng)成為***的數(shù)據(jù)交換格式之一,各大網(wǎng)站的API幾乎都支持它。

我寫過一篇《數(shù)據(jù)類型和JSON格式》,探討它的設(shè)計思想。今天,我想總結(jié)一下PHP語言對它的支持,這是開發(fā)互聯(lián)網(wǎng)應(yīng)用程序(特別是編寫API)必須了解的知識。

從5.2版本開始,PHP原生提供json_encode()和json_decode()函數(shù),前者用于編碼,后者用于解碼。

一、json_encode()

該函數(shù)主要用來將數(shù)組和對象,轉(zhuǎn)換為json格式。先看一個數(shù)組轉(zhuǎn)換的例子:

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

結(jié)果為

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

再看一個對象轉(zhuǎn)換的例子:

  1. $obj->body = 'another post';  
  2. $obj->id = 21;  
  3. $obj->approved = true;  
  4. $obj->favorite_count = 1;  
  5. $obj->status = NULL;  
  6. echo json_encode($obj); 

結(jié)果為

  1. {  
  2. "body":"another post",  
  3. "id":21,  
  4. "approved":true,  
  5. "favorite_count":1,  
  6. "status":null  
  7. }  

 由于json只接受utf-8編碼的字符,所以json_encode()的參數(shù)必須是utf-8編碼,否則會得到空字符或者null。當(dāng)中文使用GB2312編碼,或者外文使用ISO-8859-1編碼的時候,這一點要特別注意。

二、索引數(shù)組和關(guān)聯(lián)數(shù)組

PHP支持兩種數(shù)組,一種是只保存"值"(value)的索引數(shù)組(indexed array),另一種是保存"名值對"(name/value)的關(guān)聯(lián)數(shù)組(associative array)。

由于javascript不支持關(guān)聯(lián)數(shù)組,所以json_encode()只將索引數(shù)組(indexed array)轉(zhuǎn)為數(shù)組格式,而將關(guān)聯(lián)數(shù)組(associative array)轉(zhuǎn)為對象格式。

比如,現(xiàn)在有一個索引數(shù)組

  1. $arr = Array('one''two''three');  
  2. echo json_encode($arr); 

結(jié)果為:

  1. ["one","two","three"]  

如果將它改為關(guān)聯(lián)數(shù)組:

  1. $arr = Array('1'=>'one''2'=>'two''3'=>'three');  
  2. echo json_encode($arr); 

結(jié)果就變了:

  1. {"1":"one","2":"two","3":"three"}  

注意,數(shù)據(jù)格式從"[]"(數(shù)組)變成了"{}"(對象)。

如果你需要將"索引數(shù)組"強制轉(zhuǎn)化成"對象",可以這樣寫

  1. json_encode( (object)$arr ); 

或者

  1. json_encode ( $arr, JSON_FORCE_OBJECT ); 

三、類(class)的轉(zhuǎn)換

下面是一個PHP的類:

  1. class Foo {  
  2. const ERROR_CODE = '404';  
  3. public $public_ex = 'this is public';  
  4. private $private_ex = 'this is private!';  
  5. protected $protected_ex = 'this should be protected';   
  6. public function getErrorCode() {  
  7. return self::ERROR_CODE;  
  8. }  

現(xiàn)在,對這個類的實例進行json轉(zhuǎn)換:

  1. $foo = new Foo;  
  2. $foo_json = json_encode($foo);  
  3. echo $foo_json

輸出結(jié)果是

  1. {"public_ex":"this is public"}  

可以看到,除了公開變量(public),其他東西(常量、私有變量、方法等等)都遺失了。

四、json_decode()

該函數(shù)用于將json文本轉(zhuǎn)換為相應(yīng)的PHP數(shù)據(jù)結(jié)構(gòu)。下面是一個例子:

  1. $json = '{"foo": 12345}';  
  2. $obj = json_decode($json);  
  3. print $obj->{'foo'}; // 12345 

通常情況下,json_decode()總是返回一個PHP對象,而不是數(shù)組。比如:

  1. $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';  
  2. var_dump(json_decode($json)); 

結(jié)果就是生成一個PHP對象:

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

如果想要強制生成PHP關(guān)聯(lián)數(shù)組,json_decode()需要加一個參數(shù)true:

  1. $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';  
  2. var_dump(json_decode($json),true); 

結(jié)果就生成了一個關(guān)聯(lián)數(shù)組:

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

五、json_decode()的常見錯誤

下面三種json寫法都是錯的,你能看出錯在哪里嗎?

  1. $bad_json = "{ 'bar': 'baz' }";  
  2. $bad_json = '{ bar: "baz" }';  
  3. $bad_json = '{ "bar": "baz", }'

對這三個字符串執(zhí)行json_decode()都將返回null,并且報錯。

***個的錯誤是,json的分隔符(delimiter)只允許使用雙引號,不能使用單引號。第二個的錯誤是,json名值對的"名"(冒號左邊的部分),任何情況下都必須使用雙引號。第三個的錯誤是,***一個值之后不能添加逗號(trailing comma)。

另外,json只能用來表示對象(object)和數(shù)組(array),如果對一個字符串或數(shù)值使用json_decode(),將會返回null。

  1. var_dump(json_decode("Hello World")); //null 

六、參考材料

* PHP Manual (http://php.net/manual/en/book.json.php)

* Ed Finkler, JSON is Everybody's Friend (http://phpadvent.org/2008/json-is-everybodys-friend-by-ed-finkler)

原文地址:http://www.ruanyifeng.com/blog/2011/01/json_in_php.html

【編輯推薦】

  1.  Jackson框架輕易轉(zhuǎn)換JSON
  2. 技術(shù)分享 如何在Flex中使用Json
  3. 基于JSON實現(xiàn)數(shù)據(jù)列表翻頁顯示
  4. JSON數(shù)據(jù)在J2ME下的構(gòu)造和解析
  5. 闡述JSON格式舉例進行學(xué)習(xí)研究
責(zé)任編輯:于鐵 來源: 阮一峰的博客
相關(guān)推薦

2024-05-10 08:36:40

Go語言對象

2022-11-03 20:38:01

CMD命令Go

2013-06-25 09:52:32

GoGo語言Go編程

2023-03-02 19:36:34

C語言

2010-03-24 09:13:28

Python編程語言

2023-10-04 00:01:00

sizeofC 語言

2016-02-22 15:02:57

GoRedis連接池

2022-09-29 10:01:05

Go編程語言文本文件

2014-04-09 09:32:24

Go并發(fā)

2009-11-23 11:25:54

php curl

2014-08-01 15:16:05

SwiftC語言

2022-03-29 08:30:47

指針數(shù)組C語言

2011-09-07 09:51:27

Javascript

2017-03-02 09:05:56

CentOS 7Sendmail郵件

2013-12-13 17:21:14

Lua腳本語言

2023-11-17 12:04:39

GORM并發(fā)

2023-04-12 15:25:09

Bytrace鴻蒙

2009-06-25 16:49:24

Hibernate

2011-05-13 17:25:34

C

2021-06-07 23:19:44

Golang語言 Defer
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 一本岛道一二三不卡区 | av在线免费观看网站 | 国产在线二区 | 亚洲精品视频免费 | 午夜精品一区二区三区免费视频 | 日韩欧美精品一区 | 日日干日日操 | 国产成人小视频 | 国产黄视频在线播放 | 日韩在线一区二区 | 麻豆视频在线免费观看 | 在线日韩 | 国产福利在线 | 玖玖玖av| 先锋资源网站 | 精品一区二区av | 成人妇女免费播放久久久 | 欧美日韩亚洲国产综合 | 又黄又爽的网站 | 日本a在线 | 精品久久久久久18免费网站 | 国产一级淫片a直接免费看 免费a网站 | 国产日韩欧美一区 | 久久免费福利 | 欧美视频成人 | 伦理片97 | 亚洲综合色丁香婷婷六月图片 | 三级视频国产 | av电影手机版| 午夜免费网站 | 久久久精彩视频 | 亚洲精品二区 | www.天天操.com| 9色视频在线| 亚洲高清免费 | 伊人春色在线 | 亚洲狠狠| 日韩精品一区二区三区中文在线 | 色伊人 | 中文字幕一区二区三区在线观看 | 久久精品综合 |