Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Jak naprawić serializowany ciąg, który został uszkodzony przez nieprawidłową długość licznika bajtów?

unserialize() [function.unserialize]: Error at offset było spowodowane invalid serialization data z powodu nieprawidłowej długości

Szybka naprawa

To, co możesz zrobić, to recalculating the length elementów w zserializowanej tablicy

Twoje aktualne dane serializowane

$data = 'a:10:{s:16:"submit_editorial";b:0;s:15:"submit_orig_url";s:13:"www.bbc.co.uk";s:12:"submit_title";s:14:"No title found";s:14:"submit_content";s:12:"dnfsdkfjdfdf";s:15:"submit_category";i:2;s:11:"submit_tags";s:3:"bbc";s:9:"submit_id";b:0;s:16:"submit_subscribe";i:0;s:15:"submit_comments";s:4:"open";s:5:"image";s:19:"C:fakepath100.jpg";}';

Przykład bez ponownego obliczenia

var_dump(unserialize($data));

Wyjście

Notice: unserialize() [function.unserialize]: Error at offset 337 of 338 bytes

Ponowne obliczanie

$data = preg_replace('!s:(\d+):"(.*?)";!e', "'s:'.strlen('$2').':\"$2\";'", $data);
var_dump(unserialize($data));

Wyjście

array
  'submit_editorial' => boolean false
  'submit_orig_url' => string 'www.bbc.co.uk' (length=13)
  'submit_title' => string 'No title found' (length=14)
  'submit_content' => string 'dnfsdkfjdfdf' (length=12)
  'submit_category' => int 2
  'submit_tags' => string 'bbc' (length=3)
  'submit_id' => boolean false
  'submit_subscribe' => int 0
  'submit_comments' => string 'open' (length=4)
  'image' => string 'C:fakepath100.jpg' (length=17)

Zalecenie .. ja

Zamiast korzystać z tego rodzaju szybkiego rozwiązania ... radzę zaktualizować pytanie za pomocą

  • Jak serializujesz swoje dane

  • Jak to oszczędzasz ..

=================================EDYCJA 1 ========================

Błąd

Błąd został wygenerowany z powodu użycia podwójnego cudzysłowu " zamiast tego pojedynczy cudzysłów ' dlatego C:\fakepath\100.png został przekonwertowany na C:fakepath100.jpg

Aby naprawić błąd

Musisz zmienić $h->vars['submitted_data'] Od (zwróć uwagę na singe całkiem ' )

Zastąp

 $h->vars['submitted_data']['image'] = "C:\fakepath\100.png" ;

Z

 $h->vars['submitted_data']['image'] = 'C:\fakepath\100.png' ;

Dodatkowy filtr

Możesz również dodać ten prosty filtr przed wywołaniem serializacji

function satitize(&$value, $key)
{
    $value = addslashes($value);
}

array_walk($h->vars['submitted_data'], "satitize");

Jeśli masz znaki UTF, możesz również uruchomić

 $h->vars['submitted_data'] = array_map("utf8_encode",$h->vars['submitted_data']);

Jak wykryć problem w przyszłych serializowanych danych

  findSerializeError ( $data1 ) ;

Wyjście

Diffrence 9 != 7
    -> ORD number 57 != 55
    -> Line Number = 315
    -> Section Data1  = pen";s:5:"image";s:19:"C:fakepath100.jpg
    -> Section Data2  = pen";s:5:"image";s:17:"C:fakepath100.jpg
                                            ^------- The Error (Element Length)

findSerializeError Funkcja

Funkcja
function findSerializeError($data1) {
    echo "<pre>";
    $data2 = preg_replace ( '!s:(\d+):"(.*?)";!e', "'s:'.strlen('$2').':\"$2\";'",$data1 );
    $max = (strlen ( $data1 ) > strlen ( $data2 )) ? strlen ( $data1 ) : strlen ( $data2 );

    echo $data1 . PHP_EOL;
    echo $data2 . PHP_EOL;

    for($i = 0; $i < $max; $i ++) {

        if (@$data1 {$i} !== @$data2 {$i}) {

            echo "Diffrence ", @$data1 {$i}, " != ", @$data2 {$i}, PHP_EOL;
            echo "\t-> ORD number ", ord ( @$data1 {$i} ), " != ", ord ( @$data2 {$i} ), PHP_EOL;
            echo "\t-> Line Number = $i" . PHP_EOL;

            $start = ($i - 20);
            $start = ($start < 0) ? 0 : $start;
            $length = 40;

            $point = $max - $i;
            if ($point < 20) {
                $rlength = 1;
                $rpoint = - $point;
            } else {
                $rpoint = $length - 20;
                $rlength = 1;
            }

            echo "\t-> Section Data1  = ", substr_replace ( substr ( $data1, $start, $length ), "<b style=\"color:green\">{$data1 {$i}}</b>", $rpoint, $rlength ), PHP_EOL;
            echo "\t-> Section Data2  = ", substr_replace ( substr ( $data2, $start, $length ), "<b style=\"color:red\">{$data2 {$i}}</b>", $rpoint, $rlength ), PHP_EOL;
        }

    }

}

Lepszy sposób na zapisywanie w bazie danych

$toDatabse = base64_encode(serialize($data));  // Save to database
$fromDatabase = unserialize(base64_decode($data)); //Getting Save Format 


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak korzystać z pakietu zbiorczego MySQL

  2. Dodawanie danych do bazy danych Cloud Firestore

  3. Wydajność MYSQL OR vs IN

  4. Jak usunąć domyślną wartość kolumny w MySQL?

  5. Jak dodać odwołanie do łącznika MySQL dla platformy .NET?