对象的存储与传输
在实际项目应用中,有些任务在一两个页面是无法完成的,由于变量到脚本执行完毕就释放,我们本页所生成的对象想在其它页面使用时便碰到了麻烦。
如果需要将对象及其方法传递到我们想使用对象的页面,比较简单可行的办法是将对象序列化后存储起来或直接传输给需要的页面,另一种办法是将对象注册为 session 变量。
序列化对象
对象序列化,就是将对象转换成可以存储的字节流。当我们需要把一个对象在网络中传输时或者要把对象写入文件或是数据库时,就需要将对象进行序列化。
序列化完整过程包括两个步骤:一个是序列化,就是把对象转化为二进制的字符串,serialize() 函数用于序列化一个对象;另一个是反序列化,就是把对象被序列转化的二进制字符串再转化为对象,unserialize() 函数来反序列化一个被序列化的对象。这样整个过程下来,对象内的类型结构及数据都是完整的。
语法:
立即学习“PHP免费学习笔记(深入)”;
string serialize( mixed value )mixed unserialize( string str [, string callback] )
例子:
name = $name; $this->age = $age; } function say() {echo "我的名字叫:".$this->name."";echo " 我的年龄是:".$this->age; }}$p1 = new Person("张三", 20);$p1_string = serialize($p1);//将对象序列化后写入文件$fh = fopen("p1.text", "w");fwrite($fh, $p1_string);fclose($fh);?>
打开 p1.text 文件,里面写入的内容如下:
O:6:"Person":2:{s:12:" Person name";s:4:"张三";s:11:" Person age";i:20;}
但通常不去直接解析上述序列化生成的字符。
反序列化:
name = $name; $this->age = $age; } function say() {echo "我的名字叫:".$this->name."";echo " 我的年龄是:".$this->age; }}$p2 = unserialize(file_get_contents("p1.text"));$p2 -> say();?>
运行该例子,输出:
我的名字叫:张三我的年龄是:20
提示
由于序列化对象不能序列化其方法,所以在 unserialize 的时候,当前文件必须包含对应的类或者 require 对应的类文件。
序列化只能用于有限用户的情况下,因为需要为每个用户单独存储或写入文件,且保证文件名不能重复。在用户不能正常退出浏览器的情况下,不能保证文件被删除。
对象注册为 session 变量
当用户数量很多时,可以考虑用 session 来保存对象。关于 session 的更多信息,请参见《php session》。
例子:
name = $name; $this->age = $age; } function say() {echo "我的名字叫:".$this->name."";echo " 我的年龄是:".$this->age; }}$_SESSION["p1"] = new Person("张三", 20);?>
读取 session :
name = $name; $this->age = $age; } function say() {echo "我的名字叫:".$this->name."";echo " 我的年龄是:".$this->age; }}$_SESSION["p1"] -> say();?>
运行该例子,输出:
我的名字叫:张三我的年龄是:20
与序列化一样,注册对象为 session 变量时并不能保存其方法,所以在读取 session 变量的时候,当前文件必须包含对应的类或者 require 对应的类文件。