使用cookie

 

function _setHistory($data)
{
    if(!$data || !is_array($data))
    {
        return false;
    }
    //判断cookie类里面是否有浏览记录
    if($_COOKIE["_productHistory"])
    {
        $history = unserialize(stripslashes($_COOKIE['_productHistory']));

        array_unshift($history, $data); //在浏览记录顶部加入
        /* 去除重复记录 */
        $rows = array();
        foreach ($history as $v)
        {
            if(in_array($v, $rows))
            {
                continue;
            }
            $rows[] = $v;
        }
        /* 如果记录数量多余5则去除 */
        while (count($rows) > 6)
        {
            array_pop($rows); //弹出
        }
        setcookie('_productHistory',serialize($rows),time() + 3600 * 24 * 30,'/');
    }
    else
    {
        $history = array($data);
        setcookie('_productHistory',$history,time() + 3600 * 24 * 30,'/');
    }

    return ;
}

 

本人是经过了很长时间搞定的,开始在window下没问题,到linux环境就不能反序列化,最后才发现是有特殊字符导致的。

注:
serialize()–将数组转换为字符串,并保持数据结构不变
addslashes()–函数在指定的预定义字符前添加反斜杠。这些预定义字符是:
单引号 (‘)
双引号 (“)
反斜杠 (\)
NULL
stripslashes() 函数是 addslashes() 的反向操作,即:删除由 addslashes() 函数添加的反斜杠。
unserialize()  对单一的已序列化的变量进行操作,将其转换回 PHP 的值。返回的是转换之后的值,可为 integer、float、string、array 或 object。如果传递的字符串不可解序列化,则返回 FALSE。

$_COOKIE['DC_ORDERS']=serialize($_SESSION['dingcan_ShoppingCart_data']);

$cookie_info=unserialize(stripslashes($_COOKIE['DC_ORDERS']));

posted on 2014-09-15 16:53  meetcomet  阅读(453)  评论(0编辑  收藏  举报