程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 詳解PHP對象的串行化與反串行化,詳解串行

詳解PHP對象的串行化與反串行化,詳解串行

編輯:關於PHP編程

詳解PHP對象的串行化與反串行化,詳解串行


什麼時候使用串行化?

在網絡中傳輸對象的時候 向數據庫中保存文件的時候

今天我們要提到四個函數

全部串行化

1.serialize(對象名) 將指定的類對象串行化 $str=serialize($per) //將per對象串行化,結果返回給$str
2.unserialize(串行化後的返回值) 返回結果是對象 $per=unserialize($str);

局部串行化

3.__sleep() 串行化某對象的部分屬性。

4.__wakeup()反串行化時,初始化(其實是修改)對象內容

前兩個的使用方法我們大概已經介紹過,接下來我們簡單介紹一下__sleep()和__wakeup()使用方法

1.如果我們只想串行化一個對象中的部分屬性我們可以使用 __sleep()函數

在類定義中添加

function__sleep()//只序列化類中的name和age成員
{
$arr=new array('name','age'); name和age必須是類中的屬性 可以根據自己的實際需要增加
Return arr;
}

2.假如我們在類串行化的時候,per對象的name屬性值為“姜彤”在反序列化的時候我想改成"張三"怎麼辦

function __wakeup()
{
This->name="張三";
}

詳細介紹對象PHP串行化

我們大家有知道PHP串行化可以把變量包括對象,轉化成連續bytes數據,你可以將串行化後的變量存在一個文件裡或在網絡上傳輸,然後再反串行化還原為原來的數據。文章這裡就PHP串行化為大家詳細的介紹。你在反串行化類的對象之前定義的類,PHP可以成功地存儲其對象的屬性和方法. 有時你可能需要一個對象在反串行化後立即執行。為了這樣的目的,PHP會自動尋找__sleep和__wakeup方法。

當一個對象被PHP串行化,PHP會調用__sleep方法(如果存在的話). 在反串行化一個對象後,PHP 會調用__wakeup方法. 這兩個方法都不接受參數. __sleep方法必須返回一個數組,包含需要串行化的屬性. PHP會拋棄其它屬性的值。如果沒有__sleep方法,PHP將保存所有屬性。例子1顯示了如何用__sleep和__wakeup 方法來串行化一個對象. Id屬性是一個不打算保留在對象中的臨時屬性. __sleep方法保證在串行化的對象中不包含id屬性. 當反串行化一個User對象,__wakeup方法建立id屬性的新值. 這個例子被設計成自我保持. 在實際開發中,你可能發現包含資源(如圖像或數據流)的對象需要這些方法。

Listing1 Object serialization

class User 
{ 
public $name; 
public $id; 
function __construct() 
{ 
//give user a unique ID 賦予一個不同的ID 
$this->id = uniqid(); 
} 
function __sleep() 
{ 
//do not serialize this->id 不串行化id 
return(array("name")); 
} 
function __wakeup() 
{ 
//give user a unique ID 
$this->id = uniqid(); 
} 
} 
//create object 建立一個對象 
$u = new User; 
$u->name = "Leon"; 
//serialize it 串行化 注意不串行化id屬性,id的值被拋棄 
$s = serialize($u); 
//unserialize it 反串行化 id被重新賦值 
$u2 = unserialize($s); 
//$u and $u2 have different IDs $u和$u2有不同的ID 
print_r($u); 
print_r($u2); 
?> 

關於PHP對象的串行化與反串行化的相關知識就給大家介紹到這裡,希望對大家有所幫助。

您可能感興趣的文章:

  • PHP中的串行化變量和序列化對象
  • php面向對象全攻略 (十六) 對象的串行化

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved