(转)在PHP语言中使用JSON,phpjson_PHP教程

WBOY
Release: 2016-07-12 09:06:33
Original
782 people have browsed it

(转)在PHP语言中使用JSON,phpjson

原文 : 

http://www.ruanyifeng.com/blog/2011/01/json_in_php.html

------------------------------------------------------------------------

 

作者: 阮一峰

日期: 2011年1月14日

目前,JSON已经成为最流行的数据交换格式之一,各大网站的API几乎都支持它。

我写过一篇《数据类型和JSON格式》,探讨它的设计思想。今天,我想总结一下PHP语言对它的支持,这是开发互联网应用程序(特别是编写API)必须了解的知识。

从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。

一、json_encode()

该函数主要用来将数组和对象,转换为json格式。先看一个数组转换的例子:

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

结果为

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

再看一个对象转换的例子:

$obj->body           = 'another post';
  
$obj->id             = 21;
  
$obj->approved       = true;
  
$obj->favorite_count = 1;
  
$obj->status         = NULL;
  
echo json_encode($obj);
Copy after login

结果为

{
    "body":"another post",
  
    "id":21,
  
    "approved":true,
  
    "favorite_count":1,
  
    "status":null
} 
  
Copy after login

由于json只接受utf-8编码的字符,所以json_encode()的参数必须是utf-8编码,否则会得到空字符或者null。当中文使用GB2312编码,或者外文使用ISO-8859-1编码的时候,这一点要特别注意。

二、索引数组和关联数组

PHP支持两种数组,一种是只保存"值"(value)的索引数组(indexed array),另一种是保存"名值对"(name/value)的关联数组(associative array)。

由于javascript不支持关联数组,所以json_encode()只将索引数组(indexed array)转为数组格式,而将关联数组(associative array)转为对象格式。

比如,现在有一个索引数组

$arr = Array('one', 'two', 'three');
  
echo json_encode($arr);
Copy after login

结果为:

["one","two","three"] 
Copy after login

如果将它改为关联数组:

$arr = Array('1'=>'one', '2'=>'two', '3'=>'three');
   
echo json_encode($arr);
Copy after login

结果就变了:

{"1":"one","2":"two","3":"three"} 
Copy after login

注意,数据格式从"[]"(数组)变成了"{}"(对象)。

如果你需要将"索引数组"强制转化成"对象",可以这样写

json_encode( (object)$arr );
Copy after login

或者

json_encode ( $arr, JSON_FORCE_OBJECT );
Copy after login

三、类(class)的转换

下面是一个PHP的类:

class Foo {
  
    const     ERROR_CODE = '404';
  
    public    $public_ex = 'this is public';
  
    private   $private_ex = 'this is private!';
  
    protected $protected_ex = 'this should be protected'; 
   
    public function getErrorCode() {
  
      return self::ERROR_CODE;
  
    }
  
}
  
Copy after login

现在,对这个类的实例进行json转换:

$foo = new Foo;
  
$foo_json = json_encode($foo);
  
echo $foo_json;
Copy after login

输出结果是

{"public_ex":"this is public"} 
Copy after login

可以看到,除了公开变量(public),其他东西(常量、私有变量、方法等等)都遗失了。

四、json_decode()

该函数用于将json文本转换为相应的PHP数据结构。下面是一个例子:

$json = '{"foo": 12345}';
   
$obj = json_decode($json);
  
print $obj->{'foo'}; // 12345
  
Copy after login

通常情况下,json_decode()总是返回一个PHP对象,而不是数组。比如:

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

结果就是生成一个PHP对象:

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

如果想要强制生成PHP关联数组,json_decode()需要加一个参数true:

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

结果就生成了一个关联数组:

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

五、json_decode()的常见错误

下面三种json写法都是错的,你能看出错在哪里吗?

$bad_json = "{ 'bar': 'baz' }";
  
$bad_json = '{ bar: "baz" }';
  
$bad_json = '{ "bar": "baz", }';
Copy after login

对这三个字符串执行json_decode()都将返回null,并且报错。

第一个的错误是,json的分隔符(delimiter)只允许使用双引号,不能使用单引号。第二个的错误是,json名值对的"名"(冒号左边的部分),任何情况下都必须使用双引号。第三个的错误是,最后一个值之后不能添加逗号(trailing comma)。

另外,json只能用来表示对象(object)和数组(array),如果对一个字符串或数值使用json_decode(),将会返回null。

var_dump(json_decode("Hello World")); //null
Copy after login

六、参考材料

[1] PHP Manual

[2] Ed Finkler, JSON is Everybody's Friend

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1064532.htmlTechArticle(转)在PHP语言中使用JSON,phpjson 原文 : http://www.ruanyifeng.com/blog/2011/01/json_in_php.html --------------------------------------------------------------------...
Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!