php unserialize bool(false),直击php中unserialize返回false的解决方法_后端开发

715cbf15c4949187514a966cb3753638.png

本文实例报告了php中unserialize返回false的解决要领,分享给人人供人人参考。具体要领以下:

php 供应serialize(序列化) 与unserialize(反序列化)要领。

运用serialize序列化后,再运用unserialize反序列化就可以够猎取本来的数据。

先来看看以下程序实例:

$arr = array(

'name' => 'fdipzone',

'gender' => 'male'

);

$str = serialize($arr); //序列化

echo 'serialize str:'.$str."\r\n\r\n";

$content = unserialize($str); // 反序列化

echo "unserialize str:\r\n";

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

$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字符"\0"被剖析为 '\0',\0在C中是字符串的结束符即是chr(0),毛病剖析后算了2个字符。

\r在计算长度时也会出问题。

解决要领以下:

// utf8

function mb_unserialize($serial_str) {

$serial_str= preg_replace('!s:(\d+):"(.*?)";!se', "'s:'.strlen('$2').':\"$2\";'", $serial_str );

$serial_str= str_replace("\r", "", $serial_str);

return unserialize($serial_str);

}

// ascii

function asc_unserialize($serial_str) {

$serial_str = preg_replace('!s:(\d+):"(.*?)";!se', '"s:".strlen("$2").":\"$2\";"', $serial_str );

$serial_str= str_replace("\r", "", $serial_str);

return unserialize($serial_str);

}

例子:

echo '';

// utf8

function mb_unserialize($serial_str) {

$serial_str= preg_replace('!s:(\d+):"(.*?)";!se', "'s:'.strlen('$2').':\"$2\";'", $serial_str );

$serial_str= str_replace("\r", "", $serial_str);

return unserialize($serial_str);

}

$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)); // false

var_dump(mb_unserialize($str)); // 准确

运用处理过单双引号,过滤\r的mb_unserialize要领就可以胜利反序列化了。

运用unserialize:

bool(false)

运用mb_unserialize

array(9) {

["time"]=>

int(1405306402)

["name"]=>

string(6) "新晨"

["url"]=>

string(1) "-"

["word"]=>

string(1) "-"

["rpage"]=>

string(30) "http://www.baidu.com/test.html"

["cpage"]=>

string(1) "-"

["ip"]=>

string(15) "117.151.180.150"

["ip_city"]=>

string(31) "中国北京市 北京市挪动"

["miao"]=>

string(1) "5"

}

相干进修引荐:PHP编程从入门到通晓

以上就是直击php中unserialize返回false的解决要领的细致内容,更多请关注ki4网别的相干文章!

收藏 | 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值