网站地图
3936.net
学霸百科 没有你查不到的
unserialize

「官网地址0365.tv」-「永久地址0365.tv」

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

mixed unserialize ( string$str [, string$callback ] )

(PHP 4, PHP 5)

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

如果在解序列化的时候需要实例化一个未定义类,则可以设置回调函数以供调用(以免得到的是不完整的 object “__PHP_Incomplete_Class”)。可通过 php.ini、ini_set() 或 .htaccess 定义‘unserialize_callback_func’。每次实例化一个未定义类时它都会被调用。若要禁止这个特性,只需置空此设定。还需要注意的是 unserialize_callback_func 指令是从 PHP 4.2.0 开始提供使用的。

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();
  }
  }
  ?>