PHP unserialize 变量处理函数

  • 定义和用法

    unserialize - 从已存储的表示中创建 PHP 的值。
  • 版本支持

    PHP4 PHP5 PHP7
    支持 支持 支持
    4.2.0 添加了 unserialize_callback_func 指令。
  • 语法

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

    参数 必需的 描述
    str 序列化后的字符串。 若被解序列化的变量是一个对象,在成功地重新构造对象之后,PHP 会自动地试图去调用 __wakeup() 成员函数(如果存在的话)。
  • 返回值

    返回的是转换之后的值,可为 integer、float、string、array 或 object。 如果传递的字符串不可解序列化,则返回 FALSE,并产生一个 E_NOTICE。
  • 示例

    // 这里,我们使用 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();
        }
    }
    
  • 相关函数

    serialize() - 产生一个可存储的值的表示