zoukankan      html  css  js  c++  java
  • PHP之:序列化和反序列化-serialize()和unserialize()

    撰写日期:2016-7-7 10:56:40

    参考PHP在线手册(php.net):http://php.net/manual/zh/function.serialize.php

    1、序列化

    serialize() 将变量序列化

    — Generates a storable representation of a value

    — 产生一个可存储的值的表示

    说明

    serialize() 返回字符串,此字符串包含了表示 value 的字节流,可以存储于任何地方。

    这有利于存储或传递 PHP 的值,同时不丢失其类型和结构。

    想要将已序列化的字符串变回 PHP 的值,可使用 unserialize()serialize() 可处理除了 resource 之外的任何类型。甚至可以 serialize() 那些包含了指向其自身引用的数组。你正 serialize() 的数组/对象中的引用也将被存储。

    当序列化对象时,PHP 将试图在序列动作之前调用该对象的成员函数 __sleep()。这样就允许对象在被序列化之前做任何清除操作。类似的,当使用 unserialize() 恢复对象时, 将调用 __wakeup() 成员函数。

    Note:

    在 PHP 3 中,对象属性将被序列化,但是方法则会丢失。PHP 4 打破了此限制,可以同时存储属性和方法。 

    Example #1 serialize() 示例

    <?php
    // $session_data 是包含了当前用户 session 信息的多维数组。
    // 我们使用 serialize() 在请求结束之前将其存储到数据库中。

    $conn = odbc_connect ("webdb", "php", "chicken");
    $stmt = odbc_prepare ($conn,
          "UPDATE sessions SET data = ? WHERE id = ?");
    $sqldata = array (serialize($session_data), $PHP_AUTH_USER);
    if (!odbc_execute ($stmt, &$sqldata)) {
        $stmt = odbc_prepare($conn,
         "INSERT INTO sessions (id, data) VALUES(?, ?)");
        if (!odbc_execute($stmt, &$sqldata)) {
        /* 出错 */
        }
    }
    ?>

    2、解(或反)序列化函数

    unserialize — 反序列化

    — Creates a PHP value from a stored representation

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

    说明

    mixed unserialize ( string $str )

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

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

    举个栗子

    <?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 指出需要的是哪一个类
    }
    ?>
     

    注释(Warning

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

  • 相关阅读:
    函数PARSENAME使用和截取字符串
    转换为标准IPv4格式
    字母转为大写字母
    字母转为小写字母
    删除多个重复记录
    大写字母或小写字母转换为数字
    给不合法的格式转换成标准格式(案例)
    SQL SERVER动态列名
    快速生成基数的辅助表
    动态为表添加字段
  • 原文地址:https://www.cnblogs.com/942267027wzmblog/p/5649349.html
Copyright © 2011-2022 走看看