本文實例講述了php中unserialize返回false的解決方法,分享給大家供大家參考。具體方法如下:
php 提供serialize(序列化) 與unserialize(反序列化)方法。
使用serialize序列化后,再使用unserialize反序列化就可以獲取原來的數據。
先來看看如下程序實例:
<?php $arr = array( 'name' => 'fdipzone', 'gender' => 'male' ); $str = serialize($arr); //序列化 echo 'serialize str:'.$str."rnrn"; $content = unserialize($str); // 反序列化 echo "unserialize str:rn"; var_dump($content); ?>
輸出:
serialize str:a:2:{s:4:"name";s:8:"fdipzone";s:6:"gender";s:4:"male";} unserialize str: array(2) { ["name"]=> string(8) "fdipzone" ["gender"]=> string(4) "male" }
但下面這個例子反序列化會返回false
<?php $str = 'a:9:{s:4:"time";i:1405306402;s:4:"name";s:6:"新晨";s:5:"url";s:1:"-";s:4:"word";s:1:"-";s:5:"rpage";s:29:"http://www.baidu.com/test.html";s:5:"cpage";s:1:"-";s:2:"ip";s:15:"117.151.180.150";s:7:"ip_city";s:31:"中國北京市 北京市移動";s:4:"miao";s:1:"5";}'; var_dump(unserialize($str)); // bool(false) ?>
檢查序列化后的字符串,發現出問題是在兩處地方:
s:5:"url"
s:29:"http://www.baidu.com/test.html"
這兩處應為
s:3:"url"
s:30:"http://www.baidu.com/test.html"
出現這種問題的原因是序列化數據時的編碼與反序列化時的編碼不一致導致,例如數據庫是latin1和UTF-8字符長度不一樣。
另外有可能出問題的還有單雙引號,ascii字符"
主站蜘蛛池模板:
亚洲精品成人网久久久久久|
亚洲动漫精品无码av天堂|
国产精品丝袜久久久久久不卡|
在线精品自拍无码|
亚洲天堂久久精品|
人人妻人人澡人人爽人人精品97
|
亚洲国产精品不卡在线电影|
亚洲国产精品国自产拍AV|
99热热久久这里只有精品68|
久久国产精品一国产精品金尊|
欧美精品在线视频|
精品熟女少妇aⅴ免费久久|
国产亚洲美女精品久久久久狼|
欧美精品videosse精子|
香蕉依依精品视频在线播放|
国产精品自在拍一区二区不卡|
国产偷亚洲偷欧美偷精品|
国产午夜无码精品免费看|
亚洲AV无码国产精品色午友在线|
久久夜色精品国产亚洲av|
国产伦精品一区二区三区视频金莲|
国产精品视频久久|
久久精品国产精品亚洲|
久久精品蜜芽亚洲国产AV|
亚洲一区二区三区国产精品|
久久精品这里只有精99品|
国产玖玖玖九九精品视频|
91嫩草亚洲精品|
91精品国产91久久久久久青草|
国产伦精品一区二区三区女|
第一福利永久视频精品|
97久久精品午夜一区二区|
japanese乱人伦精品|
99精品免费视品|
国产精品免费观看|
欧美精品一区二区三区在线|
久久精品国内一区二区三区|
久久精品国产只有精品2020|
中文字幕亚洲精品资源网|
亚洲精品电影网|
国产三级精品久久|