PHP基礎之類和對象22——對象序列化
所謂的序列化對象就是在會話中存放對象
所有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。
相關文章: