首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Regex/ code修复损坏的序列化PHP数据。

Regex/ code修复损坏的序列化PHP数据。
EN

Stack Overflow用户
提问于 2010-06-30 19:23:28
回答 12查看 18.8K关注 0票数 20

我有一个庞大的多维数组,已经被PHP序列化了。它已存储在MySQL中,数据字段不够大...末端被切断了..。我需要提取数据。unserialize不工作..。有没有人知道可以关闭所有数组的代码...重新计算字符串长度...手工处理的数据量太大了。

非常感谢。

EN

回答 12

Stack Overflow用户

回答已采纳

发布于 2010-06-30 19:36:36

我认为这几乎是不可能的。在修复阵列之前,您需要知道阵列是如何损坏的。有多少孩子失踪了?内容是什么?

对不起,imho,你不能这么做。

证明:

代码语言:javascript
运行
复制
<?php

$serialized = serialize(
    [
        'one'   => 1,
        'two'   => 'nice',
        'three' => 'will be damaged'
    ]
);

var_dump($serialized); // a:3:{s:3:"one";i:1;s:3:"two";s:4:"nice";s:5:"three";s:15:"will be damaged";}

var_dump(unserialize('a:3:{s:3:"one";i:1;s:3:"two";s:4:"nice";s:5:"tee";s:15:"will be damaged";}')); // please note 'tee'

var_dump(unserialize('a:3:{s:3:"one";i:1;s:3:"two";s:4:"nice";s:5:"three";s:')); // serialized string is truncated

链接:https://ideone.com/uvISQu

即使您可以重新计算键/值的长度,您也不能信任从该源检索到的数据,因为您无法重新计算这些值。例如:如果序列化的数据是一个对象,那么您的属性将不再可访问。

票数 -5
EN

Stack Overflow用户

发布于 2011-04-07 20:28:11

这是重新计算序列化数组中元素的长度:

代码语言:javascript
运行
复制
$fixed = preg_replace_callback(
    '/s:([0-9]+):\"(.*?)\";/',
    function ($matches) { return "s:".strlen($matches[2]).':"'.$matches[2].'";';     },
    $serialized
);

但是,如果字符串包含";,则它不起作用。在这种情况下,不可能自动修复序列化的数组字符串--需要手动编辑。

票数 38
EN

Stack Overflow用户

发布于 2016-08-11 16:15:51

解决方案:

1)在线尝试:

2)使用函数:

unserialize( serialize_corrector($serialized_string ) ) ;

代码:

代码语言:javascript
运行
复制
function serialize_corrector($serialized_string){
    // at first, check if "fixing" is really needed at all. After that, security checkup.
    if ( @unserialize($serialized_string) !== true &&  preg_match('/^[aOs]:/', $serialized_string) ) {
        $serialized_string = preg_replace_callback( '/s\:(\d+)\:\"(.*?)\";/s',    function($matches){return 's:'.strlen($matches[2]).':"'.$matches[2].'";'; },   $serialized_string );
    }
    return $serialized_string;
} 

还有this script,我还没有测试过。

票数 23
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3148712

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档