Heim >Backend-Entwicklung >PHP-Tutorial >Teilen Sie die Verwendung von json_decode und json_encode in PHP

Teilen Sie die Verwendung von json_decode und json_encode in PHP

小云云
小云云Original
2018-03-01 14:05:281462Durchsuche

json_decode und json_encode sind beide JSON-Strings. In diesem Artikel erfahren Sie hauptsächlich, wie Sie json_decode und json_encode in PHP verwenden.

1. json_encode()

Diese Funktion wird hauptsächlich zum Konvertieren von Arrays und Objekten in das JSON-Format verwendet. Schauen wir uns zunächst ein Beispiel für die Array-Konvertierung an:

$arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5);  echo json_encode($arr); 

und das Ergebnis ist

{"a":1,"b":2,"c":3,"d":4,"e":5} 

. Schauen wir uns dann ein Beispiel für die Objektkonvertierung an:

$obj->body      = 'another post';  $obj->id       = 21;  $obj->approved    = true;  $obj->favorite_count = 1;  $obj->status     = NULL;  
echo json_encode($obj); 

und das Ergebnis ist

{    
    "body":"another post",  
  "id":21,  
  "approved":true,  
  "favorite_count":1,  
  "status":null  
  }

Da JSON nur UTF-8-kodierte Zeichen akzeptiert, müssen die Parameter von json_encode() UTF-8-kodiert sein, andernfalls erhalten Sie leere Zeichen oder Null. Wenn Chinesisch die GB2312-Kodierung verwendet oder Fremdsprachen die ISO-8859-1-Kodierung verwenden, sollte diesem Punkt besondere Aufmerksamkeit gewidmet werden.

Indiziertes Array und assoziatives Array

PHP unterstützt zwei Arten von Arrays: eines ist ein indiziertes Array, das nur „Wert“ (Wert) speichert, und das andere ist ein indiziertes Array, das „Name“ speichert value“ Ein assoziatives Array von Paaren (Name/Wert).

Da Javascript keine assoziativen Arrays unterstützt, konvertiert json_encode() nur das indizierte Array in das Array-Format und das assoziative Array in das Objektformat.

Zum Beispiel gibt es jetzt ein Index-Array

$arr = Array('one', 'two', 'three');  echo json_encode($arr); 

Das Ergebnis ist:

["eins", "zwei", "drei"]

Wenn Sie es in ein assoziatives Array ändern:

$arr = Array('1'=>'one', '2'=>'two', '3'=>'three');echo json_encode($arr); 

ändert sich das Ergebnis:

{"1": "eins", "2": "zwei", "3". : „drei“🎜>

Beachten Sie, dass sich das Datenformat von „[]“ (Array) zu „{}“ (Objekt) geändert hat.

Wenn Sie „Index-Array“ in „Objekt“ erzwingen müssen, können Sie so schreiben:

json_encode( (object)$arr ); 
oder

json_encode ( $arr, JSON_FORCE_OBJECT ); 
Klassenkonvertierung
Das Folgende ist eine PHP-Klasse:

class Foo {  
    const   ERROR_CODE = '404';  
    public  $public_ex = 'this is public';  
    private  $private_ex = 'this is private!';  
    protected $protected_ex = 'this should be protected'; 
   
    public function getErrorCode() {  
      return self::ERROR_CODE;  
    }  
  }
Führen Sie nun eine JSON-Konvertierung für die Instanz dieser Klasse durch:

$foo = new Foo;  $foo_json = json_encode($foo);  echo $foo_json; 
Das Ausgabeergebnis ist

{"public_ex":"this is public"}
Wie Sie sehen, fehlen außer öffentlichen Variablen (public) noch andere Dinge (Konstanten, private Variablen, Methoden usw.).

2. json_decode()

Diese Funktion wird verwendet, um JSON-Text in die entsprechende PHP-Datenstruktur zu konvertieren. Hier ist ein Beispiel:

$json = '{"foo": 12345}';
   $obj = json_decode($json);  print $obj->{'foo'}; // 12345 
Normalerweise gibt json_decode() immer ein PHP-Objekt zurück, kein Array. Beispiel:

$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';
var_dump(json_decode($json));
Das Ergebnis ist die Generierung eines PHP-Objekts:

object(stdClass)#1 (5) {    ["a"] => int(1)    ["b"] => int(2)    ["c"] => int(3)    ["d"] => int(4)    ["e"] => int(5)  
} 
Wenn Sie die Generierung eines assoziativen PHP-Arrays erzwingen möchten, muss json_decode() ein hinzufügen Parameter wahr:

$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';
 
var_dump(json_decode($json,true)); 
Das Ergebnis ist ein assoziatives Array:

array(5) {  
   ["a"] => int(1)     ["b"] => int(2)     ["c"] => int(3)     ["d"] => int(4)     ["e"] => int(5)  
} 
Häufige Fehler von json_decode()
Die folgenden drei Arten, JSON zu schreiben, sind alle falsch . Erkennen Sie, wo der Fehler liegt?

$bad_json = "{ 'bar': 'baz' }";  
$bad_json = '{ bar: "baz" }';  
$bad_json = '{ "bar": "baz", }'; 
Das Ausführen von json_decode() für diese drei Zeichenfolgen gibt null zurück und meldet einen Fehler.

Der erste Fehler besteht darin, dass das JSON-Trennzeichen nur die Verwendung von doppelten Anführungszeichen und nicht von einfachen Anführungszeichen zulässt. Der zweite Fehler besteht darin, dass der „Name“ (der Teil links vom Doppelpunkt) des JSON-Name-Wert-Paares auf jeden Fall in doppelte Anführungszeichen gesetzt werden muss. Der dritte Fehler besteht darin, dass Sie nach dem letzten Wert kein abschließendes Komma hinzufügen können.

Darüber hinaus kann json nur zur Darstellung von Objekten und Arrays verwendet werden. Wenn json_decode() für eine Zeichenfolge oder einen Wert verwendet wird, wird null zurückgegeben.

3. JavaScript verwendet JSON-String

Methode zum Konvertieren von JSON-String in JSON-Objekt

Verwenden Sie zuerst die folgende Methode, um in JSON-Objekt zu konvertieren:

//由JSON字符串转换为JSON对象var obj = eval('(' + str + ')');
oder

var obj = str.parseJSON(); //由JSON字符串转换为JSON对象
oder

var obj = JSON.parse(str); //由JSON字符串转换为JSON对象
Dann können Sie es so lesen:

Alert(obj.name);Alert(obj.sex);
Besonderer Hinweis: wenn obj ursprünglich ein JSON-Objekt ist , dann wird es nach der Verwendung der Funktion eval() zum Konvertieren (sogar bei mehreren Konvertierungen) immer noch ein JSON-Objekt sein, aber nach der Verwendung der Funktion parseJSON() zur Verarbeitung treten Probleme auf (Auslösen einer Syntaxausnahme).

Verwandte Empfehlungen:

Lösung für das Problem, dass json_decode das spezielle Fragezeichen in PHP nicht analysieren kann

Wie PHP json_decode implementiert unescaped Chinesische Methode Einführung

Vergleichen Sie den Unterschied zwischen json_encode und json_decode

Das obige ist der detaillierte Inhalt vonTeilen Sie die Verwendung von json_decode und json_encode in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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