所謂的序列化對象就是在會話中存放對象
所有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。