Heim > Backend-Entwicklung > PHP-Tutorial > Gründe und Lösungen für json_encode()-Funktionsfehler in PHP

Gründe und Lösungen für json_encode()-Funktionsfehler in PHP

王林
Freigeben: 2023-05-11 10:38:01
Original
3508 Leute haben es durchsucht

Mit der kontinuierlichen Weiterentwicklung von Webanwendungen ist die Dateninteraktion zu einem sehr wichtigen Bindeglied geworden. Unter diesen ist JSON (JavaScript Object Notation) ein leichtes Datenaustauschformat, das häufig für die Front-End- und Back-End-Dateninteraktion verwendet wird. In PHP kann die Funktion json_encode() ein PHP-Array oder -Objekt in eine JSON-Formatzeichenfolge konvertieren, und die Funktion json_decode() kann eine JSON-Formatzeichenfolge in ein PHP-Array oder -Objekt konvertieren. Manchmal treten jedoch Fehler in der Funktion json_encode() auf. In diesem Artikel werden die Ursachen und Lösungen für solche Fehler erläutert.

1. Häufige Fehler der json_encode()-Funktion

  1. JSON_ERROR_UTF8

Der Grund für diesen Fehler ist, dass das PHP-Array oder -Objekt ungültige UTF-8-Zeichen enthält. In PHP ist UTF-8 eine Kodierung, die zur Übertragung und Speicherung von Unicode-Zeichen im Web verwendet wird. Manchmal erscheinen jedoch einige Nicht-UTF-8-Zeichen in der Zeichenfolge, z. B. Zeichen in Codierungsformaten wie ISO-8859-1, und diese Zeichen verursachen JSON_ERROR_UTF8-Fehler. Zum Beispiel:

$array = array(
    'name' => '张三',
    'email' => '张三@example.com',

);
$json = json_encode($array);
Nach dem Login kopieren

Der obige Code generiert den Fehler JSON_ERROR_UTF8.

  1. JSON_ERROR_DEPTH

Der Grund, warum dieser Fehler auftritt, ist, dass die Ebene des PHP-Arrays oder -Objekts zu tief ist und den Grenzwert überschreitet, den die Funktion json_encode() verarbeiten kann. Standardmäßig beträgt die maximale Anzahl von Ebenen, die die Funktion json_encode() verarbeiten kann, 128. Zum Beispiel:

$array = array();
for($i = 1; $i <= 150; $i++){
    $array = array(
        'level'.$i => $array
    );
}
$json = json_encode($array);
Nach dem Login kopieren

Der obige Code generiert den Fehler JSON_ERROR_DEPTH.

  1. JSON_ERROR_RECURSION

Der Grund, warum dieser Fehler auftritt, ist, dass im PHP-Array oder -Objekt ein Zirkelverweis vorhanden ist. Zum Beispiel:

class Person{
    public $name;
    public $spouse;
}
$person1 = new Person();
$person1->name = '张三';
$person2 = new Person();
$person2->name = '李四';
$person1->spouse = $person2;
$person2->spouse = $person1;
$json = json_encode($person1);
Nach dem Login kopieren

Der obige Code generiert den Fehler JSON_ERROR_RECURSION.

  1. Andere Fehler

Zusätzlich zu den oben genannten drei Fehlern können in der Funktion json_encode() weitere Fehler auftreten, z. B. JSON_ERROR_CTRL_CHAR, JSON_ERROR_SYNTAX usw.

2. Lösung

Für unterschiedliche Fehler gibt es unterschiedliche Lösungen.

  1. JSON_ERROR_UTF8-Fehler beheben

Wenn ein PHP-Array oder -Objekt Nicht-UTF-8-Zeichen enthält, können Sie die in PHP integrierte Funktion mb_convert_encoding() verwenden, um es in das UTF-8-Format zu konvertieren. Zum Beispiel:

$array = array(
    'name' => '张三',
    'email' => '张三@example.com',

);
foreach($array as &$value){
    $value = mb_convert_encoding($value, 'UTF-8', 'GBK');
}
unset($value);
$json = json_encode($array);
Nach dem Login kopieren
  1. JSON_ERROR_DEPTH-Fehler beheben

Wenn die Ebene des PHP-Arrays oder -Objekts zu tief ist, können Sie beim Aufruf der Funktion json_encode() einen Optionsparameter übergeben, um die maximale Anzahl der Ebenen anzugeben, die verarbeitet werden können . Beispiel:

$array = array();
for($i = 1; $i <= 150; $i++){
    $array = array(
        'level'.$i => $array
    );
}
$json = json_encode($array, JSON_PARTIAL_OUTPUT_ON_ERROR | JSON_UNESCAPED_UNICODE, 512);
Nach dem Login kopieren

Im obigen Code beträgt der Wert des Optionsparameters 512, d. h. die maximale Anzahl von Ebenen beträgt 512. Wenn diese Anzahl an Ebenen überschritten wird, wird ein JSON_ERROR_DEPTH-Fehler generiert.

  1. JSON_ERROR_RECURSION-Fehler beheben

Wenn ein Zirkelverweis in einem PHP-Array oder -Objekt auftritt, können Sie den zweiten Parameter der json_encode()-Funktion verwenden, um ein durchlaufbares Objekt wie Iterator anzugeben. Beispiel:

class Person{
    public $name;
    public $spouse;
    public function jsonSerialize(){
        return [
            'name' => $this->name,
            'spouse' => $this->spouse->name
        ];
    }
}
$person1 = new Person();
$person1->name = '张三';
$person2 = new Person();
$person2->name = '李四';
$person1->spouse = $person2;
$person2->spouse = $person1;
$json = json_encode(array(
    'person1' => $person1,
    'person2' => $person2
), JSON_PARTIAL_OUTPUT_ON_ERROR, 512);
Nach dem Login kopieren

Im obigen Code implementiert die Person-Klasse die Methode jsonSerialize(), die ein Array für die Funktion json_encode() zurückgibt, um das Objekt in einen JSON-String zu serialisieren. Wenn Sie es verwenden und die Funktion json_encode() aufrufen, übergeben Sie einfach die Konstante JSON_PARTIAL_OUTPUT_ON_ERROR als zweiten Parameter.

  1. Andere Fehler lösen

Die Lösungen für andere Fehler müssen je nach Situation analysiert und bearbeitet werden.

Zusammenfassend lässt sich sagen, dass die Funktion json_encode() problemlos PHP-Arrays oder -Objekte in Zeichenfolgen im JSON-Format serialisieren kann. Bei der Verwendung müssen Sie jedoch darauf achten, ob die übergebenen Daten zulässig sind, und eine entsprechende Fehlerbehandlung durchführen.

Das obige ist der detaillierte Inhalt vonGründe und Lösungen für json_encode()-Funktionsfehler in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage