2013-10-18 24 views
19

Dies ist das erste Mal, dass ich var_dumping json_encode eines Arrays booleschen Wert ergeben.json_encode() gibt false zurück

Ich habe ein Array, das von unserialization resultierte. Ich habe es var_dumped und sichergestellt, dass es ein gültiges Array ist. Das Ergebnis ist wie folgt. Dies ist nur ein Stück, nicht die gesamte Debug-Ansicht.

array (size=3) 
'id' => string 'asco-power-technologies-l-p' (length=27) 
    'name' => string 'asco-power-technologies-l-p' (length=27) 
    'children' => 
    array (size=2) 
     0 => 
     array (size=4) 
      'id' => string 'apl-logistics' (length=13) 
      'name' => string 'APL LOGISTICS' (length=13) 
      'data' => 
      array (size=2) 
       'band' => string 'ASCO POWER TECHNOLOGIES ,L.P.' (length=29) 
       'relation' => string 'Buyer of band' (length=13) 
      'children' => 
      array (size=11) 
       0 => & 
       array (size=3) 
        'id' => string 'trisa-ag' (length=8) 
        'name' => string 'TRISA AG' (length=8) 
        'data' => 
        array (size=2) 
         'band' => string 'APL LOGISTICS' (length=13) 
         'relation' => string 'Buyer of band' (length=13) 
       1 => & 
       array (size=3) 
        'id' => string 'colgate-sanxiao-co-ltd' (length=22) 
        'name' => string 'COLGATE SANXIAO CO LTD' (length=22) 
        'data' => 
        array (size=2) 
         'band' => string 'APL LOGISTICS' (length=13) 
         'relation' => string 'Buyer of band' (length=13) 

.....

Aterwards i json_encode mit max depth = 3. Beachten Sie, ich verwende PHP 5.5 und läuft auf Apache 2.4, so dass es Tiefenparameter auf json_encode() unterstützt. Das habe ich gemacht.

$array = unserialize($serial); 
    var_dump($array); 
    $json = json_encode($array, JSON_PRETTY_PRINT, 3); 
    var_dump($json); 

Schließlich bekam ich $array var_dumped richtig und $json mit Ergebnis false boolean Wert var_dumped. Was stimmt damit nicht? Liegt es an der frühen PHP-Veröffentlichung, dass ein unangemessener var_dump einen falschen booleschen Wert ergeben würde? Ist das jemals jemandem begegnet?

UPDATE:

Dies ist die serialize String. Die gesamte Saite ist zu büschelig, also füge ich nur ein Stück hinzu.

a:3:{s:2:"id";s:27:"asco-power-technologies-l-p";s:4:"name";s:27:"asco-power-technologies-l-p";s:8:"children";a:2:{i:0;a:4:{s:2:"id";s:13:"apl-logistics";s:4:"name";s:13:"APL LOGISTICS";s:4:"data";a:2:{s:4:"band";s:29:"ASCO POWER TECHNOLOGIES ,L.P.";s:8:"relation";s:13:"Buyer of band";}s:8:"children";a:11:{i:0;a:3:{s:2:"id";s:8:"trisa-ag";s:4:"name";s:8:"TRISA AG";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:1;a:3:{s:2:"id";s:22:"colgate-sanxiao-co-ltd";s:4:"name";s:22:"COLGATE SANXIAO CO LTD";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:2;a:3:{s:2:"id";s:25:"apll-on-behalf-oftongfang";s:4:"name";s:25:"APLL ON BEHALF OFTONGFANG";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:3;a:3:{s:2:"id";s:26:"apll-on-behalf-of-zhejiang";s:4:"name";s:26:"APLL ON BEHALF OF ZHEJIANG";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:4;a:3:{s:2:"id";s:33:"apll-on-behalf-of-tongfang-global";s:4:"name";s:33:"APLL ON BEHALF OF TONGFANG GLOBAL";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:5;a:3:{s:2:"id";s:34:"apll-on-behalf-of-ningbo-xiangyuan";s:4:"name";s:34:"APLL ON BEHALF OF NINGBO XIANGYUAN";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:6;a:3:{s:2:"id";s:33:"apll-on-behalf-of-ningbo-homestar";s:4:"name";s:33:"APLL ON BEHALF OF NINGBO HOMESTAR";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:7;a:3:{s:2:"id";s:17:"apll-on-behalf-of";s:4:"name";s:17:"APLL ON BEHALF OF";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:8;a:3:{s:2:"id";s:21:"apl-logistics-sdn-bhd";s:4:"name";s:21:"APL LOGISTICS SDN BHD";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}}i:9;a:4:{s:2:"id";s:21:"apl-logistics-limited";s:4:"name";s:21:"APL LOGISTICS LIMITED";s:4:"data";a:2:{s:4:"band";s:13:"APL LOGISTICS";s:8:"relation";s:13:"Buyer of band";}s:8:"children";a:27:{i:0;a:3:{s:2:"id";s:26:"tri-phil-international-inc";s:4:"name";s:27:"TRI-PHIL INTERNATIONAL INC.";s:4:"data";a:2:{s:4:"band";s:21:"APL LOGISTICS LIMITED";s:8:"relation";s:13:"Buyer of band";}}i:1;a:3:{s:2:"id";s:16:"pt-apl-logistics";s:4:"name";s:17:"PT. APL LOGISTICS";s:4:"data";a:2:{s:4:"band";s:21:"APL LOGISTICS LIMITED";s:8:"relation";s:13:"Buyer of band";}}i:2;a:3:{s:2:"id";s:25:"keygold-manufacturing-inc";s:4:"name";s:26:"KEYGOLD ... 
+0

danke! Deine Frage hat mir geholfen! In meinem Fall gab json_encode aufgrund der Kodierung einer Variablen den Wert false zurück ... Ich musste utf8_encode zu der Variablen machen, bevor ich den json_encode ausführte ... Jetzt funktioniert es! Grüße –

Antwort

29

Die Tiefe von $array ist definitiv größer als 3. Einfach Tiefe eine größere Zahl machen. Sie können auch json_last_error verwenden, um die Fehlermeldung zu sehen, falls json_encode fehlschlägt

+0

ich chade nur die Tiefe auf 4, 5, 10 und sogar 100 und immer noch das gleiche. –

+3

json_last_error zeigt einen unbekannten Fehler an. –

+0

Wenn Sie Beispiel # 1 von der PHP-Seite verwendet haben, dann ist es höchstwahrscheinlich JSON_ERROR_RECURSION, JSON_ERROR_INF_OR_NAN oder JSON_ERROR_UNSUPPORTED_TYPE, weil sie, wenn Sie den Code nicht ändern, sie als "unbekannter Fehler" anzeigen. –