Zend_Json-xml2json.xml 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <!-- EN-Revision: 12759 -->
  2. <sect1 id="zend.json.xml2json">
  3. <title>XML to JSON conversion</title>
  4. <para><classname>Zend_Json</classname> fournit une méthode de convenance pour transformer des données au format XML en un
  5. format JSON. Ce dispositif est inspiré <ulink
  6. url="http://www.ibm.com/developerworks/xml/library/x-xml2jsonphp/">d'un article de developerWorks
  7. d'IBM</ulink>.</para>
  8. <para><classname>Zend_Json</classname> inclut une fonction statique appelée <classname>Zend_Json::fromXml()</classname>. Cette fonction
  9. produira du JSON à partir d'une entrée au format XML. Cette fonction prend n'importe quelle chaîne arbitraire XML
  10. comme paramètre d'entrée. Elle prend également un paramètre booléen facultatif d'entrée pour informer la logique de
  11. conversion d'ignorer ou non les attributs XML pendant le processus de conversion. Si ce paramètre facultatif
  12. d'entrée n'est pas donné, alors le comportement par défaut est d'ignorer les attributs XML. Cet appel de fonction
  13. est réalisé comme ceci :</para>
  14. <programlisting role="php"><![CDATA[
  15. // la fonction fromXml prend simplement une chaîne
  16. // contenant le XML comme entrée
  17. $jsonContents = Zend_Json::fromXml($xmlStringContents, true);
  18. ]]></programlisting>
  19. <para>La fonction <classname>Zend_Json::fromXml()</classname> fait la conversion du paramètre d'entrée (chaîne au format XML)
  20. et renvoie le rendu équivalent sous forme de chaîne au format JSON. En cas d'erreur, de format XML ou de logique de
  21. conversion, cette fonction lèvera une exception. La logique de conversion emploie également des techniques
  22. récursives à travers l'arbre XML. Il supporte la récursivité jusqu'à 25 niveaux de profondeur. Au delà de cette
  23. profondeur, elle lèvera une <classname>Zend_Json_Exception</classname>. Il y a plusieurs fichiers XML, avec différents niveaux
  24. de complexité, fournis dans le répertoire tests de Zend Framework. Ils peuvent être utilisés pour tester la
  25. fonctionnalité du dispositif xml2json.</para>
  26. <para>Ce qui suit est un exemple simple qui montre à la fois la chaîne XML fournie et la chaîne JSON retournée en
  27. résultat de la fonction <classname>Zend_Json::fromXml()</classname>. Cet exemple utilise le paramètre facultatif pour ne pas
  28. ignorer les attributs XML pendant la conversion. Par conséquent, vous pouvez noter que la chaîne résultante JSON
  29. inclut une représentation des attributs XML actuels de la chaîne XML fournie.</para>
  30. <para>Chaîne XML fournie à la fonction <classname>Zend_Json::fromXml()</classname> :</para>
  31. <programlisting role="php"><![CDATA[
  32. <?xml version="1.0" encoding="UTF-8"?>
  33. <books>
  34. <book id="1">
  35. <title>Code Generation in Action</title>
  36. <author><first>Jack</first><last>Herrington</last></author>
  37. <publisher>Manning</publisher>
  38. </book>
  39. <book id="2">
  40. <title>PHP Hacks</title>
  41. <author><first>Jack</first><last>Herrington</last></author>
  42. <publisher>O'Reilly</publisher>
  43. </book>
  44. <book id="3">
  45. <title>Podcasting Hacks</title>
  46. <author><first>Jack</first><last>Herrington</last></author>
  47. <publisher>O'Reilly</publisher>
  48. </book>
  49. </books>
  50. ]]></programlisting>
  51. <para>Chaîne JSON retournée par la fonction <classname>Zend_Json::fromXml()</classname> :</para>
  52. <programlisting role="php"><![CDATA[
  53. {
  54. "books" : {
  55. "book" : [ {
  56. "@attributes" : {
  57. "id" : "1"
  58. },
  59. "title" : "Code Generation in Action",
  60. "author" : {
  61. "first" : "Jack", "last" : "Herrington"
  62. },
  63. "publisher" : "Manning"
  64. }, {
  65. "@attributes" : {
  66. "id" : "2"
  67. },
  68. "title" : "PHP Hacks", "author" : {
  69. "first" : "Jack", "last" : "Herrington"
  70. },
  71. "publisher" : "O'Reilly"
  72. }, {
  73. "@attributes" : {
  74. "id" : "3"
  75. },
  76. "title" : "Podcasting Hacks", "author" : {
  77. "first" : "Jack", "last" : "Herrington"
  78. },
  79. "publisher" : "O'Reilly"
  80. }
  81. ]}
  82. }
  83. ]]></programlisting>
  84. <para>Plus de détails au sujet de ce dispositif xml2json peuvent être trouvés dans la proposition originale
  85. elle-même. Jetez un oeil à la <ulink
  86. url="http://framework.zend.com/wiki/display/ZFPROP/Zend_xml2json+-+Senthil+Nathan">proposition
  87. Zend_xml2json</ulink>.</para>
  88. </sect1>