php 中序列化和json使用介绍


Posted in Javascript onJuly 08, 2013

【序列化的概念】

序列化是将对象状态转换为可保持或可传输的格式的过程。与序列化相对的是反序列化,它将流转换为对象。这两个过程结合起来,可以轻松地存储和传输数据。

将对象的状态信息转换为可以存储或传输的窗体的过程。 在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。

通常,对象实例的所有字段都会被序列化,这意味着数据会被表示为实例的序列化数据。这样,能够解释该格式的代码有可能能够确定这些数据的值,而不依赖于该成员的可访问性。类似地,反序列化从序列化的表示形式中提取数据,并直接设置对象状态,这也与可访问性规则无关。 对于任何可能包含重要的安全性数据的对象,如果可能,应该使该对象不可序列化。如果它必须为可序列化的,请尝试生成特定字段来保存不可序列化的重要数据。如果无法实现这一点,则应注意该数据会被公开给任何拥有序列化权限的代码,并确保不让任何恶意代码获得该权限。

【JSON的概念】

JSON,JavaScript Object Notation,一种更轻、更友好的用于接口(AJAX、REST等)数据交换的格式。 JSON是结构化数据串行化的文本格式,作为XML的一种替代品,用于表示客户端与服务器间数据交换有效负载的格式。它是从ECMAScript语言标准衍生而来的。JSON的设计目标是使它成为小的、轻便的、文本的,而且是JavaScript的一个子集。

【长度的比较】

如下一段代码,显示了对数组和对象编码后生成的字符串及其长度

class Foo {
    public $int = 1;
    public $bool = TRUE;
    public $array = array(array(1), 2 => 'test', 'string');
    public function test($flag) {
        echo $flag, 'test function for Foo <br />';
    }
    public static function output($str) {
        echo $str, '<br />';
    }
    public static function compare_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('wwww' => 0, 'phppan' => 1, 'com' => 2);
//序列化数组
echo '数组:<br />';
Foo::compare_serialize_and_json($test_data);
$foo = new Foo();
echo '对象:<br />';
Foo::compare_serialize_and_json($foo);

输出:

数组:
序列化后的值:a:3:{s:4:"wwww";i:0;s:6:"phppan";i:1;s:3:"com";i:2;}; length=52
JSON后的值:{"wwww":0,"phppan":1,"com":2}; length=29
对象:
序列化后的值:O:3:"Foo":3:{s:3:"int";i:1;s:4:"bool";b:1;s:5:"array";a:3:{i:0;
    a:1:{i:0;i:1;}i:2;s:4:"test";i:3;s:6:"string";}}; length=111
JSON后的值:{"int":1,"bool":true,"array":{"0":[1],"2":"test","3":"string"}}; length=63

很明显的长度区别,serialize在编码后大概是json的两倍。

原因:

•serialize后字符串包含了子串的长度,这可能是速度方面的优化,典型的空间换时间,但是它本身还是太重了。
•serialize有更加详细的类型区分,而json只有四种类型,并且是以简单的符号表示。

【速度的比较】

以代码说明问题,如下比较速度的代码:

$max_index = 10;
ini_set("memory_limit","512M");
$array = array_fill(0, 1000000, rand(1, 9999));
echo 'serialize:<br />';
$start = xdebug_time_index();
for ($i = 0;  $i < $max_index; $i++) {
    $str = serialize($array);
}
$end = xdebug_time_index();
echo $end - $start, '<br />';
echo 'json:<br />';
$start = xdebug_time_index();
for ($i = 0;  $i < $max_index; $i++) {
    $str = json_encode($array);
}
$end = xdebug_time_index();
echo $end - $start, '<br />';
unset($array, $str);

输出:

serialize:
9.5371007919312
json:
1.4313209056854

serialize的速度在大数据量的情况下比json差了快一个数量级。

从上面两点看,json不管是在速度还是在生成的字符串的大小上都比serialize要好,那为什么serialize还要存在呢? 原因在下面这个点:实现的功能。

【处理对象】

如下代码:

header("Content-type:text/html;charset=utf8");
class Foo {
     public function test($flag) {
        echo $flag, 'test function for Foo <br />';
    }
}
$foo = new Foo();
echo '反序列化测试:<br />';
$foo->test(1);
$serialize_str = serialize($foo);
$obj = unserialize($serialize_str);
$obj->test(2);
$foo->test(1);
$json_str = json_encode($foo);
$obj = json_decode($json_str);
$obj->test(2);
die();

输出:

反序列化测试:
1test function for Foo
2test function for Foo
1test function for Foo 
( ! ) Fatal error: Call to undefined method stdClass::test()

json无法处理对象方法等数据。

【使用范围】

•序列化使用serialize,特别是对象的存储。这是其存在的意义。
•与对象无关的数据存储可以使用json,如包含大量数字的数组等。只是当遇到这种情况,我们需要做的可能是重构数据库了。
•数据交换时使用JSON,这也是其定义所在。
•目前JSON是能用于UTF-8编码的数据。

Javascript 相关文章推荐
javascript 日期时间函数(经典+完善+实用)
May 27 Javascript
javascript笔记 String类replace函数的一些事
Sep 22 Javascript
Js与下拉列表处理问题解决
Feb 13 Javascript
JavaScript实现的购物车效果可以运用在好多地方
May 09 Javascript
dreamweaver 8实现Jquery自动提示
Dec 04 Javascript
javascript基础语法——全面理解变量和标识符
Jun 02 Javascript
教大家轻松制作Bootstrap漂亮表格(table)
Dec 13 Javascript
AngularJS学习第二篇 AngularJS依赖注入
Feb 13 Javascript
bootstrap select下拉搜索插件使用方法详解
Nov 23 Javascript
百度小程序自定义通用toast组件
Jul 17 Javascript
layui table 复选框跳页后再回来保持原来选中的状态示例
Oct 26 Javascript
Vue Elenent实现表格相同数据列合并
Nov 30 Vue.js
浅析JS刷新框架中的其他页面 &amp;&amp; JS刷新窗口方法汇总
Jul 08 #Javascript
解析javascript 浏览器关闭事件
Jul 08 #Javascript
JS Jquery 遍历,筛选页面元素 自动完成(实现代码)
Jul 08 #Javascript
如何使用JS获取IE上传文件路径(IE7,8)
Jul 08 #Javascript
Jquery 模板数据绑定插件的使用方法详解
Jul 08 #Javascript
JS定义回车事件(实现代码)
Jul 08 #Javascript
使用javascript过滤html的字符串(注释标记法)
Jul 08 #Javascript
You might like
邮箱正则表达式实现代码(针对php)
2013/06/21 PHP
浅谈PHP实现大流量下抢购方案
2017/12/15 PHP
Javascript实现的鼠标经过时播放声音
2010/05/18 Javascript
仿中关村在线首页弹出式广告插件(jQuery版)
2012/05/03 Javascript
Three.js源码阅读笔记(Object3D类)
2012/12/27 Javascript
JavaScript图片轮播代码分享
2015/07/31 Javascript
jquery实现漂亮的二级下拉菜单代码
2015/08/26 Javascript
AngularJS在IE8的不支持的解决方法
2016/05/13 Javascript
js 弹出对话框(遮罩)透明,可拖动的简单实例
2016/07/11 Javascript
Vue中fragment.js使用方法详解
2017/03/09 Javascript
JavaScript利用fetch实现异步请求的方法实例
2017/07/26 Javascript
详解webpack3编译兼容IE8的正确姿势
2017/12/21 Javascript
Vue中el-form标签中的自定义el-select下拉框标签功能
2020/04/20 Javascript
[04:32]玩具屠夫中文语音节选
2020/08/23 DOTA
[02:22]完美世界DOTA2联赛PWL S3 集锦第一期
2020/12/15 DOTA
Python解释执行原理分析
2014/08/22 Python
python实现封装得到virustotal扫描结果
2014/10/05 Python
Python中设置变量访问权限的方法
2015/04/27 Python
Fabric 应用案例
2016/08/28 Python
Python操作Oracle数据库的简单方法和封装类实例
2018/05/07 Python
Python 生成 -1~1 之间的随机数矩阵方法
2018/08/04 Python
简单了解python的break、continue、pass
2019/07/08 Python
详解python opencv、scikit-image和PIL图像处理库比较
2019/12/26 Python
Python依赖包迁移到断网环境操作
2020/07/13 Python
CSS3实现瀑布流布局与无限加载图片相册的实例代码
2016/12/22 HTML / CSS
Skyscanner澳大利亚:全球领先的旅游搜索网站
2018/03/24 全球购物
Brasty波兰:香水、化妆品、手表网上商店
2019/04/15 全球购物
Gibson London官网:以地道的英国男装而著称
2019/12/06 全球购物
开办化妆品公司创业计划书
2013/12/26 职场文书
职位说明书范文
2014/05/07 职场文书
高职教师先进事迹材料
2014/08/24 职场文书
机关党员公开承诺书
2014/08/30 职场文书
北京导游词
2015/02/12 职场文书
银行实习推荐信
2015/03/27 职场文书
2016年师德师风学习心得体会
2016/01/12 职场文书
opencv深入浅出了解机器学习和深度学习
2022/03/17 Python