程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长

+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

暂无数据

从 mysql db 检索到的解码字符串

发布于2022-06-23 18:47     阅读(326)     评论(0)     点赞(0)     收藏(4)


我正在使用php 7.1.8,并且在我的 mysql 数据库中保存了以下字符串:

$dat = a:5:{i:0;s:4:"6162";i:1;s:4:"6160";i:2;s:4:"6236";i:3;s:4:"6326";i:4;s:4:"6308";}

我尝试$dat使用以下内容进行转换:

$dat = json_decode($dat, true);

然而,json_decode()回报null

有什么建议我做错了吗?


解决方案


这显然是一个序列化数组,所以我们使用

unserialize()

不是

json_decode();

我怎么知道,这些a:5:{..} i:0s:4:"6162"这是类型和数量/计数/长度。a包含 5 个项目的数组 int 0string 4“6162”也是如此。

如果这是 JSON,它将类似于 '["6162","6160","6308" ... ]'. 如您所见,JSON 占用的空间也少得多。

但是,这是序列化所采用的形式。也就是说,有一个用于会话的特殊序列化,我不太熟悉,但我不认为这是一个,特别是如果它来自 wordpress。

需要注意的一点是,虽然 Json 可以手动编辑而相当困难,但不要尝试使用这种类型的序列化,它可以完成,但它会招致灾难....哈哈

一般来说,您可以将它们视为同一类函数,它们都将复杂结构转换为字符串。序列化具有将整个对象存储在字符串中的好处(如果您想这样称呼它),这是 JSON 本身无法做到的。但是(序列化)是一个 PHP 的东西,所以它使数据的可移植性降低。更不用说如果你保存对象,这就是为什么我说它可能是一个好处,只有在考虑到这些数据的未来使用之后才应该这样做,因为它只能由 PHP 使用,并且只有当这些类保存在它仍然可以访问(如果保存了对象)。

这就是为什么很多时候您可能会看到使用 JSON 而不是序列化的原因。

 $dat = 'a:5:{i:0;s:4:"6162";i:1;s:4:"6160";i:2;s:4:"6236";i:3;s:4:"6326";i:4;s:4:"6308";}';
 var_export(unserialize($dat));

输出

array (
  0 => '6162',
  1 => '6160',
  2 => '6236',
  3 => '6326',
  4 => '6308',
);

实时测试沙盒



所属网站分类: 技术文章 > 问答

作者:黑洞官方问答小能手

链接:http://www.phpheidong.com/blog/article/349988/7aaefa92da07e0636ffa/

来源:php黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

0 0
收藏该文
已收藏

评论内容:(最多支持255个字符)