unserialize 从已存储的表示中创建 PHP 的值

发表日期:2021-07-01 08:57:22 | 来源: | | 浏览(855) 分类:变量处理 函数

unserialize

(PHP 4, PHP 5, PHP 7, PHP 8)

unserialize 从已存储的表示中创建 PHP 的值

说明

unserialize(string $str): mixed

unserialize() 对单一的已序列化的变量进行操作,将其转换回 PHP 的值。

参数

str

序列化后的字符串。

若被反序列化的变量是一个对象,在成功地重新构造对象之后,PHP 会自动地试图去调用 __wakeup() 成员函数(如果存在的话)。

注意: unserialize_callback_func 指令

如果在反序列化的时候需要实例化一个未定义类,则可以设置回调函数以供调用(以免得到的是不完整的 object “__PHP_Incomplete_Class”)。可通过 php.iniini_set().htaccess 定义‘unserialize_callback_func’。每次实例化一个未定义类时它都会被调用。若要禁止这个特性,只需置空此设定。

返回值

返回的是转换之后的值,可为 integerfloatstringarrayobject

如果传递的字符串不可反序列化,则返回 false,并产生一个 E_NOTICE

更新日志

版本 说明
4.2.0 添加了 unserialize_callback_func 指令。

范例

示例 #1 unserialize() 例子

<?php 
// 这里,我们使用 unserialize() 装载来自数据库的 $session_data 数组中的会话数据。// 此例是描述 serialize() 的那个例子的补充。$conn = odbc_connect("webdb", "php", "chicken");
$stmt = odbc_prepare($conn, "SELECT data FROM sessions WHERE id = ?");
$sqldata = array($_SERVER['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();
    }
}
?>

示例 #2 unserialize_callback_func 例子

<?php 
$serialized_object='O:1:"a":1:{
s:5:"value";
s:3:"100";
}
';
// unserialize_callback_func 从 PHP 4.2.0 起可用ini_set('unserialize_callback_func', 'mycallback');
 // 设置您的回调函数function mycallback($classname) {
   // 只需包含含有类定义的文件   // $classname 指出需要的是哪一个类}
?>

注释

警告

如果反序列化了 false 的值,或者在过程中发生了错误,都会返回 false。 可以通过 strserialize(false) 进行比较,或者捕捉 E_NOTICE 错误来判断这种特殊情况。

参见

集速网 copyRight © 2015-2022 宁ICP备15000399号-1 宁公网安备 64010402001209号
与其临渊羡鱼,不如退而结网
欢迎转载、分享、引用、推荐、收藏。