unserialize

unserialize是對單一的已序列化的變數進行操作,將其轉換回 PHP 的值。

基本介紹

  • 外文名:unserialize
  • 實質:是PHP的一個函式
  • 功能:從已存儲的表示中創建 PHP 的值
  • 返回值類型:integer float string array 
描述,注意1,注意2,例子,

描述

mixed unserialize ( string$str [, string$callback ] )
(PHP 4, PHP 5)
對單一的已序列化的變數進行操作,將其轉換回 PHP 的值。

注意1

如果在解序列化的時候需要實例化一個未定義類,則可以設定回調函式以供調用(以免得到的是不完整的 object “__PHP_Incomplete_Class”)。可通過 php.ini、ini_set() 或 .htaccess 定義‘unserialize_callback_func’。每次實例化一個未定義類時它都會被調用。若要禁止這個特性,只需置空此設定。還需要注意的是 unserialize_callback_func 指令是從 PHP 4.2.0 開始提供使用的。

注意2

callback 參數是在 PHP 4.2.0 中添加的

例子

<?php
// 這裡,我們使用 unserialize() 裝載來自資料庫的 $session_data 數組中的會話數據。
// 此例是描述 serialize() 的那個例子的補充。
$conn = odbc_connect ("webdb", "php", "chicken");
$stmt = odbc_prepare ($conn, "SELECT data FROM sessions WHERE id = ?");
$sqldata = array ($PHP_AUTH_USER);
if (!odbc_execute ($stmt, &$sqldata) || !odbc_fetch_into ($stmt, &$tmp)) {
// 如果執行出錯或返回錯誤,則初始化為空數組
$session_data = array();
} else {
// 現在我們需要的是 $tmp[0] 中已序列化的數據。
$session_data = unserialize ($tmp[0]);
if (!is_array ($session_data)) {
// 出錯,初始化為空數組
$session_data = array();
}
}
?>

相關詞條

熱門詞條

聯絡我們