XML zu JSON Konvertierung

Zend_Json bietet eine bequeme Methode für das transformieren von XML formatierten Daten in das JSON Format. Dieses Feature wurde inspiriert durch einen » IBM developerWorks Artikel.

Zend_Json enthält eine statische Funktion die Zend_Json::fromXml() heißt. Diese Funktion erzeugt JSON von einer angegebenen XML Eingabe. Diese Funktion nimmt jeglichen beliebigen XML String als Eingabe Parameter. Sie nimmt auch einen optionalen Boolschen Eingabe Parameter um die Konvertierungslogik zu instruieren ob XML Attribute während des Konvertierungsprozesses ignoriert werden sollen oder nicht. Wenn dieser optionale Eingabeparameter nicht angegeben wurde, besteht das Standardverhalten darun XML Attribute zu ignorieren. Der Funktionsaufruf wird wie folgt durchgeführt:

  1. // Die fromXml Funktion nimmt einfach einen String der XML
  2. // Inhalt als Eingabe enthält.
  3. $jsonContents = Zend_Json::fromXml($xmlStringContents, true);

Die Zend_Json::fromXml() Funktion führt die Konvertierung des XML formatierten String Eingabeparameters durch und gibt eine äquivalente JSON formatierte String Ausgabe zurück. Im Fall eines XML Eingabeformat Fehlers oder eines Konvertierungslogik Fehlers wird diese Funktion eine Ausnahme werfen. Die Konvertierungslogik verwendet rekursive Techniken um den XML Baum zu durchlaufen. Sie unterstützt Rekursionen die bis zu 25 Levels tief sind. Über diese Tiefe hinweg wird Sie eine Zend_Json_Exception werfen. Es gibt verschiedenste XML Dateien mit unterschiedlichem Grad an Komplexität die im tests Verzeichnis des Zend Frameworks vorhanden sind. Sie können verwendet werden um die Funktionalität des xml2json Features zu testen.

Das folgende ist ein einfaches Beispiel das beides zeigt, den XML Eingabe String und den JSON Ausgabe String der als Ergebnis von der Zend_Json::fromXml() Funktion zurückgegeben wird. Dieses Beispiel verwendet den optionalen Funktionsparameter um die XML Attribute nicht während der Konvertierung zu ignorieren. Demzufolge kann man sehen das der resultierende JSON String eine Repräsentation der XML Attribute enthält die im XML Eingabestring vorhanden sind.

XML Eingabe String der an die Zend_Json::fromXml() Funktion übergeben wird:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <books>
  3.     <book id="1">
  4.         <title>Code Generation in Action</title>
  5.         <author><first>Jack</first><last>Herrington</last></author>
  6.         <publisher>Manning</publisher>
  7.     </book>
  8.  
  9.     <book id="2">
  10.         <title>PHP Hacks</title>
  11.         <author><first>Jack</first><last>Herrington</last></author>
  12.         <publisher>O'Reilly</publisher>
  13.     </book>
  14.  
  15.     <book id="3">
  16.         <title>Podcasting Hacks</title>
  17.         <author><first>Jack</first><last>Herrington</last></author>
  18.         <publisher>O'Reilly</publisher>
  19.     </book>
  20. </books>

JSON Ausgabe String der von der Zend_Json::fromXml() Funktion zurückgegeben wird:

  1. {
  2.    "books" : {
  3.       "book" : [ {
  4.          "@attributes" : {
  5.             "id" : "1"
  6.          },
  7.          "title" : "Code Generation in Action",
  8.          "author" : {
  9.             "first" : "Jack", "last" : "Herrington"
  10.          },
  11.          "publisher" : "Manning"
  12.       }, {
  13.          "@attributes" : {
  14.             "id" : "2"
  15.          },
  16.          "title" : "PHP Hacks", "author" : {
  17.             "first" : "Jack", "last" : "Herrington"
  18.          },
  19.          "publisher" : "O'Reilly"
  20.       }, {
  21.          "@attributes" : {
  22.             "id" : "3"
  23.          },
  24.          "title" : "Podcasting Hacks", "author" : {
  25.             "first" : "Jack", "last" : "Herrington"
  26.          },
  27.          "publisher" : "O'Reilly"
  28.       }
  29.    ]}
  30. }

Weitere Details über das xml2json Feature können im originalen Proposal selbst gefunden werden. Siehe » Zend_xml2json proposal.

blog comments powered by Disqus