php json,php json_decode
各位老铁们,大家好,今天由我来为大家分享php json,以及php json_decode的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!
如何正确运用PHP json
从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。
1、json_encode()
该函数主要用来将数组和对象,转换为json格式。先看一个数组转换的例子:
$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}
再看一个对象转换的例子:
复制代码代码如下:
$obj->body='another post';
$obj->id= 21;
$obj->approved= true;
$obj->favorite_count= 1;
$obj->status= NULL;
echo json_encode($obj);
以上代码的输出结果为:
复制代码代码如下:
{
"body":"another post",
"id":21,
"approved":true,
"favorite_count":1,
"status":null
}
由于json只接受utf-8编码的字符,所以json_encode()的参数必须是utf-8编码,否则会得到空字符或者null。当中文使用GB2312编码,或者外文使用ISO-8859-1编码的时候,这一点要特别注意。
2、索引数组和关联数组
PHP支持两种数组,一种是只保存"值"(value)的索引数组(indexed array),另一种是保存"名值对"(name/value)的关联数组(associative array)。
由于javascript不支持关联数组,所以json_encode()只将索引数组(indexed array)转为数组格式,而将关联数组(associative array)转为对象格式。
比如,现在有一个索引数组:
$arr= Array('one','two','three');
echo json_encode($arr);
其输出结果为:
["one","two","three"]
如果将它改为关联数组:
$arr= Array('1'=>'one','2'=>'two','3'=>'three');
echo json_encode($arr);
结果就变了:
{"1":"one","2":"two","3":"three"}
注意,数据格式从"[]"(数组)变成了"{}"(对象)。
如果你需要将"索引数组"强制转化成"对象",可以这样写
json_encode((object)$arr);
或者:
json_encode($arr, JSON_FORCE_OBJECT);
3、类(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;
}
}
现在,对这个类的实例进行json转换:
复制代码代码如下:
$foo= new Foo;
$foo_json= json_encode($foo);
echo$foo_json;
输出结果是:
{"public_ex":"this is public"}
可以看到,除了公开变量(public),其他东西(常量、私有变量、方法等等)都遗失了。
4、json_decode()
该函数用于将json文本转换为相应的PHP数据结构。下面是一个例子:
复制代码代码如下:
$json='{"foo": 12345}';
$obj= json_decode($json);
print$obj->{'foo'};// 12345
通常情况下,json_decode()总是返回一个PHP对象,而不是数组。比如:
$json='{"a":1,"b":2,"c":3,"d":4,"e":5}';
var_dump(json_decode($json));
结果就是生成一个PHP对象:
复制代码代码如下:
object(stdClass)#1(5){
["a"]=> int(1)
["b"]=> int(2)
["c"]=> int(3)
["d"]=> int(4)
["e"]=> int(5)
}
如果想要强制生成PHP关联数组,json_decode()需要加一个参数true:
$json='{"a":1,"b":2,"c":3,"d":4,"e":5}';
var_dump(json_decode($json),true);
结果就生成了一个关联数组:
复制代码代码如下:
array(5){
["a"]=> int(1)
["b"]=> int(2)
["c"]=> int(3)
["d"]=> int(4)
["e"]=> int(5)
}
5、json_decode()的常见错误
下面三种json写法都是错的,你能看出错在哪里吗?
复制代码代码如下:
$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。
var_dump(json_decode("Hello World"));//null
php 中序列化和json使用介绍
【序列化的概念】
序列化是将对象状态转换为可保持或可传输的格式的过程与序列化相对的是反序列化它将流转换为对象这两个过程结合起来可以轻松地存储和传输数据
将对象的状态信息转换为可以存储或传输的窗体的过程在序列化期间对象将其当前状态写入到临时或持久性存储区以后可以通过从存储区中读取或反序列化对象的状态重新创建该对象
通常对象实例的所有字段都会被序列化这意味着数据会被表示为实例的序列化数据这样能够解释该格式的代码有可能能够确定这些数据的值而不依赖于该成员的可访问性类似地反序列化从序列化的表示形式中提取数据并直接设置对象状态这也与可访问性规则无关对于任何可能包含重要的安全性数据的对象如果可能应该使该对象不可序列化如果它必须为可序列化的请尝试生成特定字段来保存不可序列化的重要数据如果无法实现这一点则应注意该数据会被公开给任何拥有序列化权限的代码并确保不让任何恶意代码获得该权限
【JSON的概念】
JSON JavaScript Object Notation一种更轻更友好的用于接口(AJAX REST等)数据交换的格式 JSON是结构化数据串行化的文本格式作为XML的一种替代品用于表示客户端与服务器间数据交换有效负载的格式它是从ECMAScript语言标准衍生而来的 JSON的设计目标是使它成为小的轻便的文本的而且是JavaScript的一个子集
【长度的比较】
如下一段代码显示了对数组和对象编码后生成的字符串及其长度
复制代码代码如下: class Foo{ public$int=; public$bool= TRUE; public$array= array(array()=> test string);
public function test($flag){ echo$flag test function for Foo<br/>;}
public static function output($str){ echo$str<br/>;}
public static function pare_serialize_and_json($data){$serialize_str= serialize($data); self::output(序列化后的值:$serialize_str"; length=" strlen($serialize_str));
$json_str= json_encode($data); self::output( JSON后的值:$json_str"; length=" strlen($json_str));}
}
$test_data= array( w=> phppan=>=>);//序列化数组
echo数组<br/>; Foo::pare_serialize_and_json($test_data);
$foo= new Foo(); echo对象:<br/>; Foo::pare_serialize_and_json($foo);
输出
复制代码代码如下:数组序列化后的值:a::{s::"w";i:;s::"phppan";i:;s::"";i:;}; length= JSON后的值:{"w":"phppan":"":}; length=对象:序列化后的值:O::"Foo"::{s::"int";i:;s::"bool";b:;s::"array";a::{i:; a::{i:;i:;}i:;s::"test";i:;s::"string";}}; length= JSON后的值:{"int":"bool":true"array":{"":[ ]"":"test""":"string"}}; length=很明显的长度区别 serialize在编码后大概是json的两倍
原因
•serialize后字符串包含了子串的长度这可能是速度方面的优化典型的空间换时间但是它本身还是太重了•serialize有更加详细的类型区分而json只有四种类型并且是以简单的符号表示
【速度的比较】
以代码说明问题如下比较速度的代码
复制代码代码如下:$max_index=; ini_set("memory_limit"" M");$array= array_fill( rand()); echo serialize<br/>;$start= xdebug_time_index(); for($i=;$i<$max_index;$i++){$str= serialize($array);}$end= xdebug_time_index(); echo$end$start<br/>;
echo json<br/>;$start= xdebug_time_index(); for($i=;$i<$max_index;$i++){$str= json_encode($array);}$end= xdebug_time_index(); echo$end$start<br/>; unset($array$str);
输出
复制代码代码如下: serialize json serialize的速度在大数据量的情况下比json差了快一个数量级
从上面两点看 json不管是在速度还是在生成的字符串的大小上都比serialize要好那为什么serialize还要存在呢?原因在下面这个点实现的功能
【处理对象】
如下代码
复制代码代码如下: header("Content type:text/;charset=utf"); class Foo{ public function test($flag){ echo$flag test function for Foo<br/>;}}$foo= new Foo();
echo反序列化测试<br/>;$foo>test();$serialize_str= serialize($foo);$obj= unserialize($serialize_str);$obj>test();
$foo>test();$json_str= json_encode($foo);$obj= json_decode($json_str);$obj>test(); die();
输出
复制代码代码如下:反序列化测试 test function for Foo test function for Foo test function for Foo(!) Fatal error: Call to undefined method stdClass::test()
json无法处理对象方法等数据
【使用范围】
lishixinzhi/Article/program/PHP/201311/20931
php怎么接收json类型数据
PHP接收JSON格式的数据
在API服务中,目前流行采用json形式来交互。
给前端调用的接口输出Json数据,这个比较简单,只需要组织好数据,用json_encode($array)转化一下,前端就得到json格式的数据。
接收前端提交的json数据稍微复杂一点,原因是:PHP默认识别的数据类型是application/x-www.form-urlencoded标准的数据类型。因此,对型如text/xml或者 soap或者 application/octet-stream和application/json格式之类的内容无法解析,如果用$_POST数组来接收就会失败!
此时可以使用$GLOBALS['HTTP_RAW_POST_DATA']或 file_get_contents('php://input')来获取提交的数据
查看手册,可以发现$GLOBALS['HTTP_RAW_POST_DATA']和$_POST的区别:
$_POST:通过 HTTP POST方法传递的变量组成的数组,是自动全局变量。
$GLOBALS['HTTP_RAW_POST_DATA']:总是产生$HTTP_RAW_POST_DATA变量包含有原始的 POST数据。此变量仅在碰到未识别 MIME类型的数据时产生。$HTTP_RAW_POST_DATA对于 enctype="multipart/form-data"表单数据不可用。也就是说基本上$GLOBALS['HTTP_RAW_POST_DATA']和$_POST是一样的。但是如果post过来的数据不是PHP能够识别的,你可以用$GLOBALS['HTTP_RAW_POST_DATA']来接收,比如 text/xml或者 soap等等。
补充说明:PHP默认识别的数据类型是application/x-www.form-urlencoded标准的数据类型。
关于php json到此分享完毕,希望能帮助到您。