PHP中文手册

版权信息

PHP 手册

入门指引

安装与配置

语言参考

安全

特点

函数参考

PHP 核心:骇客指南

FAQ

附录

对象序列化

序列化对象 - 在会话中存放对象

所有php里面的值都可以使用函数 serialize() 来返回一个包含字节流的字符串来表示。 unserialize() 函数能够重新把字符串变回php原来的值。 序列化一个对象将会保存对象的所有变量,但是不会保存对象的方法,只会保存类的名字。

为了能够 unserialize() 一个对象,这个对象的类必须已经定义过。如果序列化类A的一个对象,将会返回一个跟类A相关,而且包含了对象所有变量值的字符串。 如果要想在另外一个文件中解序列化一个对象,这个对象的类必须在解序列化之前定义,可以通过包含一个定义该类的文件或使用函数 spl_autoload_register() 来实现。

<?php
// classa.inc:
  
  
class  {
      public 
$one  1 ;
    
      public function 
show_one () {
          echo 
$this -> one ;
      }
  }
  
// page1.php:

  
include( "classa.inc" );
  
  
$a  = new  A ;
  
$s  serialize ( $a );
  
// 把变量$s保存起来以便文件page2.php能够读到
  
file_put_contents ( 'store' $s );

// page2.php:
  
  // 要正确了解序列化,必须包含下面一个文件
  
include( "classa.inc" );

  
$s  file_get_contents ( 'store' );
  
$a  unserialize ( $s );

  
// 现在可以使用对象$a里面的函数 show_one()
  
$a -> show_one ();
?>

当一个应用程序使用函数 session_register() 来保存对象到会话中时,在每个页面结束的时候这些对象都会自动序列化,而在每个页面开始的时候又自动解序列化。 所以一旦对象被保存在会话中,整个应用程序的页面都能使用这些对象。但是, session_register() 这个函数在php5.3.0已经废弃,而且在php6.0.0就不再支持,所以不要依赖这个函数。

在应用程序中序列化对象以便在之后使用,强烈推荐在整个应用程序都包含对象的类的定义。 不然有可能出现在解序列化对象的时候,没有找到该对象的类的定义,从而把没有方法的类__PHP_Incomplete_Class_Name作为该对象的类,导致返回一个没有用的对象。

所以在上面的例子中,当运行session_register("a"),把变量 $a 放在会话里之后,需要在每个页面都包含文件classa.inc,而不是只有文件page1.phppage2.php