Zend_Rest_Server.xml 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <!-- EN-Revision: 11089 -->
  2. <sect1 id="zend.rest.server">
  3. <title>Zend_Rest_Server</title>
  4. <sect2 id="zend.rest.server.introduction">
  5. <title>Introduction</title>
  6. <para>Zend_Rest_Server est prévu comme un serveur supportant l'ensemble des fonctionnalités d'un serveur
  7. REST.</para>
  8. </sect2>
  9. <sect2 id="zend.rest.server.usage">
  10. <title>Utilisation d'un serveur REST</title>
  11. <example id="zend.rest.server.usage.example-1">
  12. <title>Utilisation basique Zend_Rest_Server - Avec des classes</title>
  13. <programlisting role="php"><![CDATA[
  14. $server = new Zend_Rest_Server();
  15. $server->setClass('Mon_Service_Classe');
  16. $server->handle();
  17. ]]></programlisting>
  18. </example>
  19. <example id="zend.rest.server.usage.example-2">
  20. <title>Utilisation basique Zend_Rest_Server - Avec des fonctions</title>
  21. <programlisting role="php"><![CDATA[
  22. /**
  23. * Dit Bonjour
  24. *
  25. * @param string $qui
  26. * @param string $quand
  27. * @return string
  28. */
  29. function ditBonjour($qui, $quand)
  30. {
  31. return "Bonjour $qui, bonne $quand";
  32. }
  33. $server = new Zend_Rest_Server();
  34. $server->addFunction('ditBonjour');
  35. $server->handle();
  36. ]]></programlisting>
  37. </example>
  38. </sect2>
  39. <sect2 id="zend.rest.server.args">
  40. <title>Appelé un service Zend_Rest_Server</title>
  41. <para>Pour appeler un service <classname>Zend_Rest_Server</classname>, vous devez fournir un argument de
  42. <code>method</code> GET/POST avec une valeur qui est la méthode que vous souhaitez appeler. Vous pouvez alors
  43. ajouter tout nombre d'arguments en utilisant le nom de l'argument (c.-à-d. "qui ") ou en utilisant 'arg' suivi
  44. de la position numérique de l'argument (c.-à-d. "arg1").</para>
  45. <note>
  46. <title>Index numérique</title>
  47. <para>Les arguments numériques utilisent 1 comme point de départ.</para>
  48. </note>
  49. <para>Pour appeler le <code>ditBonjour</code> de l'exemple ci-dessus, vous pouvez employer soit :</para>
  50. <para><code>?method=ditBonjour&amp;qui=Davey&amp;quand=journée</code></para>
  51. <para>or:</para>
  52. <para><code>?method=ditBonjour&amp;arg1=Davey&amp;arg2=journée</code></para>
  53. </sect2>
  54. <sect2 id="zend.rest.server.customstatus">
  55. <title>Envoyer un statut personnalisé</title>
  56. <para>En envoyant des valeurs, pour ajouter un statut personnalisé, vous pouvez envoyer un tableau avec une clé
  57. <code>status</code>.</para>
  58. <example id="zend.rest.server.customstatus.example-1">
  59. <title>Renvoyer un statut personnalisé</title>
  60. <programlisting role="php"><![CDATA[
  61. /**
  62. * Dit Bonjour
  63. *
  64. * @param string $qui
  65. * @param string $quand
  66. * @return array
  67. */
  68. function ditBonjour($qui, $quand)
  69. {
  70. return array('msg' => "Une erreur est apparue", 'status' => false);
  71. }
  72. $server = new Zend_Rest_Server();
  73. $server->addFunction('ditBonjour');
  74. $server->handle();
  75. ]]></programlisting>
  76. </example>
  77. </sect2>
  78. <sect2 id="zend.rest.server.customxml">
  79. <title>Renvoyer une réponse XML personnalisée</title>
  80. <para>Si vous voulez retourner du XML personnalisé, retournez simplement un objet <code>DOMDocument</code>,
  81. <code>DOMElement</code> ou <code>SimpleXMLElement</code>.</para>
  82. <example id="zend.rest.server.customxml.example-1">
  83. <title>Renvoyer une réponse XML personnalisée</title>
  84. <programlisting role="php"><![CDATA[
  85. /**
  86. * Dit Bonjour
  87. *
  88. * @param string $who
  89. * @param string $when
  90. * @return SimpleXMLElement
  91. */
  92. function ditBonjour($qui, $quand)
  93. {
  94. $xml ='<?xml version="1.0" encoding="ISO-8859-1"?>
  95. <mysite>
  96. <value>Salut $qui! J\'espère que tu passes une bonne $when</value>
  97. <code>200</code>
  98. </mysite>';
  99. $xml = simplexml_load_string($xml);
  100. return $xml;
  101. }
  102. $server = new Zend_Rest_Server();
  103. $server->addFunction('ditBonjour');
  104. $server->handle();
  105. ]]></programlisting>
  106. </example>
  107. <para>La réponse du service sera retournée sans modification au client.</para>
  108. </sect2>
  109. </sect1>