所謂的序列化物件就是在會話中存放物件
所有php裡面的值都可以使用函數 serialize()來傳回一個包含位元組流的字串來表示。 unserialize()函數能夠重新把字串變回php原來的值。 序列化一個物件將會保存物件的所有變量,但是不會保存物件的方法,只會保存類別的名字。
為了能夠 unserialize()一個對象,這個對象的類別必須已經定義過。如果序列化類別A的一個對象,將會傳回一個跟類別A相關,而且包含了對象所有變數值的字串。 如果要想在另一個檔案中解序列化一個對象,這個物件的類別必須在解序列化之前定義,可以透過包含一個定義該類別的檔案或使用函數 spl_autoload_register()來實現。
<?php // classa.inc: class A { 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.php和page2. php。