XML to JSON conversion

Zend_Json fournit une méthode de convenance pour transformer des données au format XML en un format JSON. Ce dispositif est inspiré » d'un article de developerWorks d'IBM.

Zend_Json inclut une fonction statique appelée Zend_Json::fromXml(). Cette fonction produira du JSON à partir d'une entrée au format XML. Cette fonction prend n'importe quelle chaîne arbitraire XML comme paramètre d'entrée. Elle prend également un paramètre booléen facultatif d'entrée pour informer la logique de conversion d'ignorer ou non les attributs XML pendant le processus de conversion. Si ce paramètre facultatif d'entrée n'est pas donné, alors le comportement par défaut est d'ignorer les attributs XML. Cet appel de fonction est réalisé comme ceci :

  1. // la fonction fromXml prend simplement une chaîne
  2. // contenant le XML comme entrée
  3. $jsonContents = Zend_Json::fromXml($xmlStringContents, true);

La fonction Zend_Json::fromXml() fait la conversion du paramètre d'entrée (chaîne au format XML) et renvoie le rendu équivalent sous forme de chaîne au format JSON. En cas d'erreur, de format XML ou de logique de conversion, cette fonction lèvera une exception. La logique de conversion emploie également des techniques récursives à travers l'arbre XML. Il supporte la récursivité jusqu'à 25 niveaux de profondeur. Au delà de cette profondeur, elle lèvera une Zend_Json_Exception. Il y a plusieurs fichiers XML, avec différents niveaux de complexité, fournis dans le répertoire tests de Zend Framework. Ils peuvent être utilisés pour tester la fonctionnalité du dispositif xml2json.

Ce qui suit est un exemple simple qui montre à la fois la chaîne XML fournie et la chaîne JSON retournée en résultat de la fonction Zend_Json::fromXml(). Cet exemple utilise le paramètre facultatif pour ne pas ignorer les attributs XML pendant la conversion. Par conséquent, vous pouvez noter que la chaîne résultante JSON inclut une représentation des attributs XML actuels de la chaîne XML fournie.

Chaîne XML fournie à la fonction Zend_Json::fromXml() :

  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>

Chaîne JSON retournée par la fonction Zend_Json::fromXml() :

  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. }

Plus de détails au sujet de ce dispositif xml2json peuvent être trouvés dans la proposition originale elle-même. Jetez un oeil à la » proposition Zend_xml2json.

blog comments powered by Disqus