Heim  >  Artikel  >  Backend-Entwicklung  >  So verwenden Sie JSON in der PHP-Sprache und stellen JSON in einem Array wieder her

So verwenden Sie JSON in der PHP-Sprache und stellen JSON in einem Array wieder her

不言
不言Original
2018-06-02 13:48:051350Durchsuche

Dieser Artikel stellt hauptsächlich die Methode zur Verwendung von JSON in der PHP-Sprache und zum Reduzieren von JSON in ein Array vor. Jetzt kann ich ihn mit Ihnen teilen.

Ich habe Ich habe gerade ein einfaches Beispiel für die Rückgabe von JSON-Daten in PHP geschrieben und plötzlich einen Artikel gefunden, der auch JSON vorstellte. Der Inhalt ist wie folgt

Ab Version 5.2 stellt PHP nativ die Funktionen json_encode() und json_decode() bereit, wobei ersteres zum Kodieren und letzteres zum Dekodieren verwendet wird.

1. json_encode()

<?php 
$arr = array (&#39;a&#39;=>1,&#39;b&#39;=>2,&#39;c&#39;=>3,&#39;d&#39;=>4,&#39;e&#39;=>5); 
echo json_encode($arr); 
?>

Ausgabe

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

Sehen Sie sich ein weiteres Beispiel für die Objektkonvertierung an:

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

Ausgabe

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

Da JSON nur UTF-8-codierte Zeichen akzeptiert, müssen die Parameter von json_encode() UTF-8-codiert 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.

2. Indizierte Arrays und assoziative Arrays

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

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 Indexarray

$arr = Array(&#39;one&#39;, &#39;two&#39;, &#39;three&#39;); 
   
  echo json_encode($arr);

Ausgabe

["one","two","three"]

Wenn Sie es in ein assoziatives Array ändern:

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

wird die Ausgabe zu

{"1":"one","2":"two","3":"three"}

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

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 );

3. Klassenkonvertierung

Das Folgende ist eine PHP-Klasse:

class Foo { 
   
    const   ERROR_CODE = &#39;404&#39;; 
   
    public  $public_ex = &#39;this is public&#39;; 
   
    private  $private_ex = &#39;this is private!&#39;; 
   
    protected $protected_ex = &#39;this should be protected&#39;; 
    
    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) andere Dinge (Konstanten, private Variablen, Methoden usw.).

4. json_decode()

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

 $json = &#39;{"foo": 12345}&#39;; 
    
  $obj = json_decode($json); 
   
  print $obj->{&#39;foo&#39;}; // 12345

Normalerweise gibt json_decode() immer ein PHP-Objekt zurück, kein Array. Zum 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() einen Parameter true hinzufügen:

$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) 
   
  }

5. Häufige Fehler von json_decode()

Die folgenden drei Arten, JSON zu schreiben, sind alle falsch Siehst du, wo der Fehler liegt?

$bad_json = "{ &#39;bar&#39;: &#39;baz&#39; }"; 
   
  $bad_json = &#39;{ bar: "baz" }&#39;; 
   
  $bad_json = &#39;{ "bar": "baz", }&#39;;

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“ des JSON-Name-Wert-Paares (der Teil links vom Doppelpunkt) unter allen Umständen in doppelten Anführungszeichen verwendet 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.

var_dump(json_decode("Hello World")); //null

Verwandte Empfehlungen:

php Methoden zum Lesen, Schreiben und Ändern von JSON-Dateien

Das obige ist der detaillierte Inhalt vonSo verwenden Sie JSON in der PHP-Sprache und stellen JSON in einem Array wieder her. 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