(PHP 4, PHP 5, PHP 7, PHP 8)
serialize — 產(chǎn)生一個(gè)可存儲(chǔ)的值的表示
serialize() 返回字符串,此字符串包含了表示
value
的字節(jié)流,可以存儲(chǔ)于任何地方。
這有利于存儲(chǔ)或傳遞 PHP 的值,同時(shí)不丟失其類(lèi)型和結(jié)構(gòu)。
想要將已序列化的字符串變回 PHP 的值,可使用 unserialize()。serialize() 可處理除了 resource 之外的任何類(lèi)型。甚至可以 serialize() 那些包含了指向其自身引用的數(shù)組。你正 serialize() 的數(shù)組/對(duì)象中的引用也將被存儲(chǔ)。
當(dāng)序列化對(duì)象時(shí),PHP 將試圖在序列動(dòng)作之前調(diào)用該對(duì)象的成員函數(shù) __sleep()。這樣就允許對(duì)象在被序列化之前做任何清除操作。類(lèi)似的,當(dāng)使用 unserialize() 恢復(fù)對(duì)象時(shí), 將調(diào)用 __wakeup() 成員函數(shù)。
注意:
在 PHP 3 中,對(duì)象屬性將被序列化,但是方法則會(huì)丟失。PHP 4 打破了此限制,可以同時(shí)存儲(chǔ)屬性和方法。請(qǐng)參見(jiàn)類(lèi)與對(duì)象中的序列化對(duì)象部分獲取更多信息。
示例 #1 serialize() 示例
<?php
// $session_data 是包含了當(dāng)前用戶(hù) session 信息的多維數(shù)組。
// 我們使用 serialize() 在請(qǐng)求結(jié)束之前將其存儲(chǔ)到數(shù)據(jù)庫(kù)中。
$conn = odbc_connect ("webdb", "php", "chicken");
$stmt = odbc_prepare ($conn,
"UPDATE sessions SET data = ? WHERE id = ?");
$sqldata = array (serialize($session_data), $PHP_AUTH_USER);
if (!odbc_execute ($stmt, &$sqldata)) {
$stmt = odbc_prepare($conn,
"INSERT INTO sessions (id, data) VALUES(?, ?)");
if (!odbc_execute($stmt, &$sqldata)) {
/* 出錯(cuò) */
}
}
?>
參見(jiàn):unserialize()。