***在PHP语言中使用JSON和将json还原成数组(json_decode()的常见错误)

简介: 在之前我写过php返回json数据简单实例,刚刚上网,突然发现一篇文章,也是介绍json的,还挺详细,值得参考。内容如下 从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。

在之前我写过php返回json数据简单实例,刚刚上网,突然发现一篇文章,也是介绍json的,还挺详细,值得参考。内容如下

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

一、json_encode()

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

输出

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

 

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

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

 输出

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

 由于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)转为对象格式。

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

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

 输出

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

 如果将它改为关联数组:

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

 输出变为

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

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

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

1
json_encode( (object) $arr  );

 或者

1
json_encode (  $arr , JSON_FORCE_OBJECT );

 三、类(class)的转换

下面是一个PHP的类:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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;
 
  }
 
}

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

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

 输出结果是

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

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

四、json_decode()

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

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

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

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

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

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

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

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

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

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

五、json_decode()的常见错误

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

1
2
3
4
5
$bad_json  "{ 'bar': 'baz' }" ;
 
$bad_json  '{ bar: "baz" }' ;
 
$bad_json  '{ "bar": "baz", }' ;

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

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

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

1
var_dump(json_decode( "Hello World" ));  //null
如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
14天前
|
JSON Go 数据格式
Golang语言结构体链式编程与JSON序列化
这篇文章是关于Go语言中结构体链式编程与JSON序列化的教程,详细介绍了JSON格式的基本概念、结构体的序列化与反序列化、结构体标签的使用以及如何实现链式编程。
21 4
|
1月前
|
SQL 数据库连接 PHP
php常见错误
【8月更文挑战第3天】php常见错误
15 6
|
1月前
|
JSON 前端开发 JavaScript
php中JSON或数组到formData的键值对转换
转换JSON或数组到formData格式的键值对并不复杂。PHP的 `json_decode()`与 `http_build_query()`是实现这一转换过程的关键函数。理解这个转换过程对于开发中处理各种AJAX请求时调整数据格式至关重要。这样,无论是处理来自客户端的JSON字符串,还是服务器端的数组数据,都能够灵活地转换为适合网络传输的格式,确保数据交换的顺畅和高效。
47 4
|
28天前
|
SQL JSON 关系型数据库
"SQL老司机大揭秘:如何在数据库中玩转数组、映射与JSON,解锁数据处理的无限可能,一场数据与技术的激情碰撞!"
【8月更文挑战第21天】SQL作为数据库语言,其能力不断进化,尤其是在处理复杂数据类型如数组、映射及JSON方面。例如,PostgreSQL自8.2版起支持数组类型,并提供`unnest()`和`array_agg()`等函数用于数组的操作。对于映射类型,虽然SQL标准未直接支持,但通过JSON数据类型间接实现了键值对的存储与查询。如在PostgreSQL中创建含JSONB类型的表,并使用`-&gt;&gt;`提取特定字段或`@&gt;`进行复杂条件筛选。掌握这些技巧对于高效管理现代数据至关重要,并预示着SQL在未来数据处理领域将持续扮演核心角色。
28 0
|
1月前
|
JSON JavaScript 数据格式
Jquery 将 JSON 列表的 某个属性值,添加到数组中,并判断一个值,在不在数据中
Jquery 将 JSON 列表的 某个属性值,添加到数组中,并判断一个值,在不在数据中
51 0
|
3月前
|
JSON 关系型数据库 MySQL
MySQL中GROUP_CONCAT与JSON_OBJECT、GROUP BY的巧妙结合:打造高效JSON数组汇总
MySQL中GROUP_CONCAT与JSON_OBJECT、GROUP BY的巧妙结合:打造高效JSON数组汇总
|
3月前
|
JSON PHP 数据格式
蓝易云 - PHP用CURL发送Content-type为application/json的POST请求方法
在这段代码中,我们首先创建了一个包含我们要发送的数据的数组,并使用 `json_encode`函数将其转换为JSON格式。然后,我们初始化了一个cURL会话,并设置了一些选项,包括POST请求方法、要发送的数据、返回结果和HTTP头部信息。最后,我们执行了cURL请求并关闭了会话。
92 2
|
4月前
|
JSON JavaScript 前端开发
Golang深入浅出之-Go语言JSON处理:编码与解码实战
【4月更文挑战第26天】本文探讨了Go语言中处理JSON的常见问题及解决策略。通过`json.Marshal`和`json.Unmarshal`进行编码和解码,同时指出结构体标签、时间处理、omitempty使用及数组/切片区别等易错点。建议正确使用结构体标签,自定义处理`time.Time`,明智选择omitempty,并理解数组与切片差异。文中提供基础示例及时间类型处理的实战代码,帮助读者掌握JSON操作。
83 1
Golang深入浅出之-Go语言JSON处理:编码与解码实战
|
3月前
|
JSON 资源调度 Kubernetes
实时计算 Flink版操作报错合集之解析JSON数组时,遇到报错,该怎么解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
3月前
|
JSON JavaScript 数据格式
1.js动态的往json数据添加新属性和值 2.JSON 和 JS 对象互转 3.对象转化为数组
1.js动态的往json数据添加新属性和值 2.JSON 和 JS 对象互转 3.对象转化为数组
41 0