标签:
举个栗子:
<?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();
}
}
?>
Example #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
。 可以通过 str
和serialize(false) 进行比较,或者捕捉 E_NOTICE
错误来判断这种特殊情况。
PHP之:序列化和反序列化-serialize()和unserialize()
标签:
原文地址:http://www.cnblogs.com/942267027wzmblog/p/5649349.html