Zend_Soap_Wsdl.xml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 13768 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.soap.wsdl">
  5. <title>WSDL</title>
  6. <note>
  7. <para>La classe <classname>Zend_Soap_Wsdl</classname> est utilisée par le composant Zend_Soap_Server pour manipuler des
  8. documents WSDL. Néanmoins, vous pouvez vous-même utiliser les services fournis par cette classe pour vos propres
  9. besoins. La classe Zend_Soap_Wsdl contient à la fois un analyseur et un constructeur de documents WSDL.</para>
  10. <para>Si vous ne voulez pas l'utiliser pour vos propres besoins, vous pouvez alors passer cette section de la
  11. documentation.</para>
  12. </note>
  13. <sect2 id="zend.soap.wsdl.constructor">
  14. <title>Constructeur <classname>Zend_Soap_Wsdl</classname></title>
  15. <para>Le constructeur de <classname>Zend_Soap_Wsdl</classname> prend 3 paramètres : <orderedlist>
  16. <listitem>
  17. <simpara><code>$name</code> - nom du service Web décrit.</simpara>
  18. </listitem>
  19. <listitem>
  20. <simpara><code>$uri</code> - URI d'accès au fichier WSDL. (Une référence dans le système de fichier
  21. local est possible.)</simpara>
  22. </listitem>
  23. <listitem>
  24. <simpara><code>$strategy</code> - identifiant optionnel pour identifier la détection de stratégie
  25. des types complexes. Ceci est un booléen <code>$extractComplexTypes</code> avant la version 1.7 et
  26. peut toujours être paramétrer via un booléen pour la compatibilité ascendante. Par défaut le
  27. comportement de détection de la 1.6 est activé. Pour avoir de plus amples informations concernant
  28. les stratégies de détection des types complexes, lisez : <xref
  29. linkend="zend.soap.wsdl.types.add_complex" />.</simpara>
  30. </listitem>
  31. </orderedlist></para>
  32. </sect2>
  33. <sect2 id="zend.soap.wsdl.addmessage">
  34. <title><code>addMessage()</code></title>
  35. <para><code>addMessage($name, $parts)</code> ajoute un message de description au document WSDL
  36. (/definitions/message de l'élément).</para>
  37. <para>Chaque message correspond à une méthode en terme de fonctionnalité de <classname>Zend_Soap_Server</classname> et
  38. <classname>Zend_Soap_Client</classname>.</para>
  39. <para>Le paramètre <code>$name</code> représente le nom du message.</para>
  40. <para>Le paramètre <code>$parts</code> est un tableau de paramètre des messages décrivant les paramètres d'appel
  41. SOAP. Le tableau est associatif: 'nom du paramètre' (nom du paramètre d'appel SOAP) =&gt; 'type du
  42. paramètre'.</para>
  43. <para>La correspondance de types est effectuée grâce à <code>addTypes()</code> et
  44. <code>addComplexType()</code>(voyez après).</para>
  45. <note>
  46. <para>Les paramètres de messages peuvent être soit "element", soit "type" (voyez <ulink
  47. url="http://www.w3.org/TR/wsdl#_messages"></ulink>).</para>
  48. <para>"element" doit correspondre à un élément de définition de type. "type" correspond à une entrée
  49. complexType.</para>
  50. <para>Tous les types standards XSD possèdent une définition "element" et "complexType" (Voyez <ulink
  51. url="http://schemas.xmlsoap.org/soap/encoding/"></ulink>).</para>
  52. <para>Tous les éléments non standards, qui doivent être ajoutés avec la méthode
  53. <classname>Zend_Soap_Wsdl::addComplexType()</classname>, sont décrits en utilisant un noeud "complexType" décrits dans
  54. la section "/definitions/types/schema/" du document WSDL.</para>
  55. <para>Ainsi, la méthode <code>addMessage()</code> utilise toujours un attribut "type" pour décrire des
  56. types.</para>
  57. </note>
  58. </sect2>
  59. <sect2 id="zend.soap.wsdl.add_port_type">
  60. <title><code>addPortType()</code></title>
  61. <para><code>addPortType($name)</code> ajoute un nouveau type de portage au document WSDL
  62. (/definitions/portType).</para>
  63. <para>Ceci fait la jointure entre des méthodes du service décrites en tant qu'implémentations de
  64. Zend_Soap_Server.</para>
  65. <para>Voyez <ulink url="http://www.w3.org/TR/wsdl#_porttypes"></ulink> pour plus de détails.</para>
  66. </sect2>
  67. <sect2 id="zend.soap.wsdl.add_port_operation">
  68. <title><code>addPortOperation()</code></title>
  69. <para><code>addPortOperation($portType, $name, $input = false, $output = false, $fault = false)</code> ajoute
  70. des définitions de portage au portage défini dans le document WSDL (/definitions/portType/operation).</para>
  71. <para>Chaque opération de portage correspond à une méthode de classe (si le Web Service est basé sur une classe)
  72. ou à une fonction (si le Web Service est basé sur des fonctions), ceci en terme d'implémentation de
  73. Zend_Soap_Server.</para>
  74. <para>Cette méthode ajoute aussi les messages d'opération correspondants aux portages, ceci dépend des
  75. paramètres <code>$input</code>, <code>$output</code> and <code>$fault</code>. <note>
  76. <para>Zend_Soap_Server génère 2 messages pour chaque opération de portage lorsque le service est décrit
  77. au travers de la classe <classname>Zend_Soap_Server</classname>: <itemizedlist>
  78. <listitem>
  79. <para>Le message d'entrée nommé <code>$methodName . 'Request'</code>.</para>
  80. </listitem>
  81. <listitem>
  82. <para>Les message de sortie nommé <code>$methodName . 'Response'</code>.</para>
  83. </listitem>
  84. </itemizedlist></para>
  85. </note></para>
  86. <para>Voyez <ulink url="http://www.w3.org/TR/wsdl#_request-response"></ulink> pour les détails.</para>
  87. </sect2>
  88. <sect2 id="zend.soap.wsdl.add_binding">
  89. <title><code>addBinding()</code></title>
  90. <para><code>addBinding($name, $portType)</code> ajoute de nouvelles correspondances (bindings) au document WSDL
  91. (/definitions/binding).</para>
  92. <para>Le noeud du document WSDL "binding" définit le format du message et les détails du protocole pour les
  93. opérations et messages définis par un portage "portType" particulier (voyez <ulink
  94. url="http://www.w3.org/TR/wsdl#_bindings"></ulink>).</para>
  95. <para>La méthode crée le noeud de correspondance et le retourne. Il peut alors être utilisé.</para>
  96. <para>L'implémentation de Zend_Soap_Server utilise le nom <code>$serviceName . "Binding"</code> pour la
  97. correspondance ("binding") de l'élément du document WSDL.</para>
  98. </sect2>
  99. <sect2 id="zend.soap.wsdl.add_binding_operation">
  100. <title><code>addBindingOperation()</code></title>
  101. <para><code>addBindingOperation($binding, $name, $input = false, $output = false, $fault = false)</code> ajoute
  102. une opération à l'élément de correspondance avec le nom spécifié (/definitions/binding/operation).</para>
  103. <para>Cette méthode prend un objet <code>XML_Tree_Node</code> tel que retourné par <code>addBinding()</code>, en
  104. paramètre (<code>$binding</code>) pour ajouter un élément "operation" avec des entrées input/output/false
  105. dépendantes des paramètres spécifiés.</para>
  106. <para><classname>Zend_Soap_Server</classname> ajoute les correspondances pour chaque méthode du Web Service avec des
  107. entrées et sorties, définissant l'élément "soap:body" comme <code>&lt;soap:body use="encoded"
  108. encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"/&gt;</code></para>
  109. <para>Voyez les détails à <ulink url="http://www.w3.org/TR/wsdl#_bindings"></ulink>.</para>
  110. </sect2>
  111. <sect2 id="zend.soap.wsdl.add_soap_binding">
  112. <title><code>addSoapBinding()</code></title>
  113. <para><code>addSoapBinding($binding, $style = 'document', $transport =
  114. 'http://schemas.xmlsoap.org/soap/http')</code> ajoute des correspondances (bindings) SOAP ("soap:binding") à
  115. l'élément (déjà lié à un portage de type) avec le style et le transport spécifié (<classname>Zend_Soap_Server</classname>
  116. utilise le style RPC sur HTTP).</para>
  117. <para>L'élément "/definitions/binding/soap:binding" est alors utilisé pour spécifier que la correspondance est
  118. relative au format du protocole SOAP.</para>
  119. <para>Voyez <ulink url="http://www.w3.org/TR/wsdl#_bindings"></ulink> pour les détails.</para>
  120. </sect2>
  121. <sect2 id="zend.soap.wsdl.add_soap_operation">
  122. <title><code>addSoapOperation()</code></title>
  123. <para><code>addSoapOperation($binding, $soap_action)</code> ajoute une opération SOAP ("soap:operation") à
  124. l'élément de correspondance avec l'action spécifiée. L'attribut "style" de l'élément "soap:operation" n'est pas
  125. utilisé alors que le modèle de programmation (RPC-oriented ou document-oriented) devrait utiliser la méthode
  126. <code>addSoapBinding()</code></para>
  127. <para>L'attribut "soapAction" de l'élément "/definitions/binding/soap:operation" spécifie la valeur de l'en-tête
  128. SOAPAction pour l'opération. Cet attribut est requis pour SOAP sur HTTP et <emphasis>ne doit pas</emphasis> être
  129. renseigné pour les autres modes de transports.</para>
  130. <para><classname>Zend_Soap_Server</classname> utilise <code>$serviceUri . '#' . $methodName</code> pour le nom de l'action
  131. SOAP.</para>
  132. <para>Voyez <ulink url="http://www.w3.org/TR/wsdl#_soap:operation"></ulink> pour plus de détails.</para>
  133. </sect2>
  134. <sect2 id="zend.soap.wsdl.add_service">
  135. <title><code>addService()</code></title>
  136. <para><code>addService($name, $port_name, $binding, $location)</code> ajoute un élément "/definitions/service"
  137. au document WSDL avec le nom du Web Service spécifié, le nom du portage, la correspondance, et l'adresse.</para>
  138. <para>WSDL 1.1 autorise d'avoir plusieurs types de portage par service. Cette particularité n'est pas utilisée
  139. dans <classname>Zend_Soap_Server</classname> et est non supportée par la classe <classname>Zend_Soap_Wsdl</classname>.</para>
  140. <para>Utilisations de <classname>Zend_Soap_Server</classname> : <itemizedlist>
  141. <listitem>
  142. <para><code>$name . 'Service'</code> comme nom du Web Service,</para>
  143. </listitem>
  144. <listitem>
  145. <para><code>$name . 'Port'</code> comme nom de portage des types,</para>
  146. </listitem>
  147. <listitem>
  148. <para><code>'tns:' . $name . 'Binding'</code> <footnote>
  149. <para><code>'tns:' namespace</code> est l'URI du script (<code>'http://'
  150. .$_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME']</code>).</para>
  151. </footnote> comme nom de la correspondance,</para>
  152. </listitem>
  153. <listitem>
  154. <para>l'URI du script<footnote>
  155. <para><code>'http://' .$_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME']</code></para>
  156. </footnote> en tant qu'URI du service pour les Web Service utilisant des classes.</para>
  157. </listitem>
  158. </itemizedlist> où <code>$name</code> est un nom de classe pour le Web Service utilisant des classes, ou un
  159. nom de script pour le Web Service qui utilise des fonctions.</para>
  160. <para>Voyez <ulink url="http://www.w3.org/TR/wsdl#_services"></ulink> pour les détails.</para>
  161. </sect2>
  162. <sect2 id="zend.soap.wsdl.types">
  163. <title>Correspondance de type</title>
  164. <para>Le WSDL de Zend_Soap utilise les correspondances suivantes pour faire correspondre les type SOAP à des
  165. types PHP : <itemizedlist>
  166. <listitem>
  167. <para>chaînes PHP &lt;-&gt; <code>xsd:string</code>.</para>
  168. </listitem>
  169. <listitem>
  170. <para>entiers PHP &lt;-&gt; <code>xsd:int</code>.</para>
  171. </listitem>
  172. <listitem>
  173. <para>flottants PHP &lt;-&gt; <code>xsd:float</code>.</para>
  174. </listitem>
  175. <listitem>
  176. <para>booléens PHP &lt;-&gt; <code>xsd:boolean</code>.</para>
  177. </listitem>
  178. <listitem>
  179. <para>tableaux PHP &lt;-&gt; <code>soap-enc:Array</code>.</para>
  180. </listitem>
  181. <listitem>
  182. <para>objets PHP &lt;-&gt; <code>xsd:struct</code>.</para>
  183. </listitem>
  184. <listitem>
  185. <para>Classe PHP &lt;-&gt; basé sur la stratégie des types complexes (Voir : <xref
  186. linkend="zend.soap.wsdl.types.add_complex" />)<footnote>
  187. <para><classname>Zend_Soap_AutoDiscover</classname> sera créé avec la classe
  188. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname> en tant qu'algorithme de détection
  189. pour les types complexes. Le premier paramètre du constructeur AutoDiscover accepte toute
  190. stratégie de types complexes implémentant <classname>Zend_Soap_Wsdl_Strategy_Interface</classname> ou
  191. une chaîne correspondant au nom de la classe. Pour une compatibilité ascendante, avec
  192. <code>$extractComplexType</code> les variables booléennes sont analysées comme avec
  193. Zend_Soap_Wsdl. Regardez le manuel <link
  194. linkend="zend.soap.wsdl.types.add_complex">Zend_Soap_Wsdl sur l'ajout des types
  195. complexes</link> pour plus d'informations.</para>
  196. </footnote>.</para>
  197. </listitem>
  198. <listitem>
  199. <para>Type PHP vide &lt;-&gt; void.</para>
  200. </listitem>
  201. <listitem>
  202. <para>Si le type na aucune correspondance avec les valeurs ci-dessus, alors <code>xsd:anyType</code>
  203. est utilisé.</para>
  204. </listitem>
  205. </itemizedlist> Où <code>xsd:</code> est l'espace de noms "http://www.w3.org/2001/XMLSchema",
  206. <code>soap-enc:</code> est l'espace de noms "http://schemas.xmlsoap.org/soap/encoding/", <code>tns:</code> est
  207. un "espace de noms cible" pour le service.</para>
  208. <sect3 id="zend.soap.wsdl.types.retrieve">
  209. <title>Récupérer des infos sur les types</title>
  210. <para><code>getType($type)</code> peut être utilisée pour récupérer la correspondance d'un type PHP spécifié
  211. : <programlisting role="php"><![CDATA[
  212. ...
  213. $wsdl = new Zend_Soap_Wsdl('My_Web_Service', $myWebServiceUri);
  214. ...
  215. $soapIntType = $wsdl->getType('int');
  216. ...
  217. class MyClass {
  218. ...
  219. }
  220. ...
  221. $soapMyClassType = $wsdl->getType('MyClass');
  222. ]]></programlisting></para>
  223. </sect3>
  224. <sect3 id="zend.soap.wsdl.types.add_complex">
  225. <title>Ajouter des infos sur les types complexes</title>
  226. <para><code>addComplexType($type)</code> est utilisée pour ajouter des types complexes (classes PHP) à un
  227. document WSDL.</para>
  228. <para>C'est automatiquement utilisé par la méthode <code>getType()</code> pour ajouter les types complexes
  229. des paramètres de méthodes ou des types retournés.</para>
  230. <para>Sa détection et son algorithme de construction est basé sur la détection de stratégie des types
  231. complexes couramment active. Vous pouvez paramétrer la stratégie de détection soit en spécifiant le nom de
  232. classe sous la forme d'une chaîne de caractères ou une instance implémentant
  233. <classname>Zend_Soap_Wsdl_Strategy_Interface</classname> en tant que troisième paramètre du constructeur ou en
  234. utilisant la fonction <code>setComplexTypeStrategy($strategy)</code> de <classname>Zend_Soap_Wsdl</classname>. Les
  235. stratégies de détection suivantes existent couramment :</para>
  236. <itemizedlist>
  237. <listitem>
  238. <para>la classe <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname> : activé par défaut (quand
  239. aucun troisième paramètre n'est fourni). Itère parmi les attributs publics d'un type de classe et
  240. les enregistre en tant que sous-types d'un type d'objet complexe.</para>
  241. </listitem>
  242. <listitem>
  243. <para>la classe <classname>Zend_Soap_Wsdl_Strategy_AnyType</classname> : caste tous les types complexes en un
  244. type XSD simple xsd:anyType. Attention ce raccourci pour la détection des types complexes peut
  245. probablement seulement être géré avec des langages faiblement typés comme le PHP.</para>
  246. </listitem>
  247. <listitem>
  248. <para>la classe <classname>Zend_Soap_Wsdl_Strategy_ArrayOfTypeSequence</classname> : cette stratégie permet de
  249. spécifier les paramètres de retour de type : <code>int[]</code> ou <code>string[]</code>. Il peut
  250. seulement gérer les types PHP simples comme int, string, boolean, float et ainsi de suite, mais
  251. permet de spécifier des tableaux imbriqués de tableaux de type.</para>
  252. </listitem>
  253. <listitem>
  254. <para>la classe <classname>Zend_Soap_Wsdl_Strategy_ArrayOfTypeComplex</classname> : cette stratégie permet de
  255. détecter des tableaux complexes d'objets. Les types d'objets sont détectés sur la base de
  256. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname> et un tableau enveloppe cette
  257. définition.</para>
  258. </listitem>
  259. <listitem>
  260. <para>la classe <classname>Zend_Soap_Wsdl_Strategy_Composite</classname> : cette stratégie peut combiner
  261. toutes les stratégies en connectant les types complexes PHP (nom de classe) à la stratégie désirée
  262. grâce à la méthode <code>connectTypeToStrategy($type, $strategy)</code>. Une carte de correspondance
  263. complète de types peut être fourni au constructeur sous la forme d'un tableau de paires
  264. <code>$type</code> -&gt; <code>$strategy</code>. Le second paramètre spécifie la stratégie par
  265. défaut si un type inconnu est ajouté. La valeur par défaut de ce paramètre est la stratégie
  266. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>.</para>
  267. </listitem>
  268. </itemizedlist>
  269. <para>la méthode <code>addComplexType()</code> crée un élément
  270. "<code>/definitions/types/xsd:schema/xsd:complexType</code>" pour chaque type complexe décrit avec le nom
  271. d'une classe PHP spécifiée.</para>
  272. <para>Les propriétés des classes <emphasis>doivent</emphasis> posséder un bloc de documentation avec le type
  273. PHP en question, afin que la propriété soit incluse dans la description WSDL.</para>
  274. <para><code>addComplexType()</code> vérifie sur le type est déjà décrit dans la section des types du
  275. document WSDL.</para>
  276. <para>Ceci évite les duplications et récursions si cette méthode est appelée plus d'une fois.</para>
  277. <para>Voyez <ulink url="http://www.w3.org/TR/wsdl#_types"></ulink> pour plus de détails.</para>
  278. </sect3>
  279. </sect2>
  280. <sect2 id="zend.soap.wsdl.add_documentation">
  281. <title><code>addDocumentation()</code></title>
  282. <para><code>addDocumentation($input_node, $documentation)</code> ajoute de la documentation lisible ("human
  283. readable") grâce à l'élément optionnel "wsdl:document".</para>
  284. <para>L'élément "/definitions/binding/soap:binding" est utilisé pour dire que la correspondance est liée au
  285. format du protocole SOAP.</para>
  286. <para>Voyez <ulink url="http://www.w3.org/TR/wsdl#_documentation"></ulink> pour les détails.</para>
  287. </sect2>
  288. <sect2 id="zend.soap.wsdl.retrieve">
  289. <title>Récupérer un document WSDL finalisé</title>
  290. <para><code>toXML()</code>, <code>toDomDocument()</code> et <code>dump($filename = false)</code> peuvent être
  291. utilisées pour récupérer un document WSDL sous forme de XML, de structure DOM, ou de fichier.</para>
  292. </sect2>
  293. <sect2 id="zend.soap.wsdl.parser">
  294. <title>Analyse des documents WSDL</title>
  295. <para>Zend_Soap_Wsdl contient aussi un analyseur de documents WSDL qui a son application la plus importante dans
  296. les tests unitaires et dans la génération de code pour les services Web SOAP (client et serveur). L'exemple
  297. suivant vous montre comment l'analyseur peut être utilisé :</para>
  298. <programlisting role="php"><![CDATA[
  299. // Chargement du WSDL dans un DOMDocument
  300. $dom = new DOMDocument();
  301. $dom->loadXML($wsdlString);
  302. // Création de l'analyseur
  303. $parser = Zend_Soap_Wsdl_Parser::factory($dom);
  304. $result = $parser->parse();
  305. // Nom du service Web
  306. echo $result->getName();
  307. // Ports d'accès et éléments internes
  308. foreach($result->ports AS $port) {
  309. echo $port->getName();
  310. foreach($port->bindings AS $binding) {
  311. echo $binding->getName();
  312. foreach($binding->operations AS $operation) {
  313. echo $operation->getName();
  314. echo $operation->inputMessage->getName();
  315. echo $operation->outputMessage->getName();
  316. }
  317. }
  318. }
  319. // Vous pouvez accéder aux liaisons (bindings), aux messages, aux opérations
  320. // et tout autre éléments directement
  321. foreach($result->operations AS $operation) {
  322. // faire qqch
  323. }
  324. foreach($result->bindings AS $binding {
  325. // faire qqch
  326. }
  327. foreach($result->messages AS $message) {
  328. // faire qqch
  329. }
  330. foreach($result->services AS $service) {
  331. // faire qqch
  332. }
  333. foreach($result->types AS $type) {
  334. // faire qqch
  335. }
  336. ]]></programlisting>
  337. <para>Tous les éléments implémentent l'interface <classname>Zend_Soap_Wsdl_Element_Interface</classname> qui déclare les
  338. fonctions <code>getName()</code> et <code>getDocumentation()</code> fournissant respectivement un identifiant
  339. unique de l'élément et sa documentation. Tous les éléments possèdent des propriétés publiques qui décrivent son
  340. état avec plus de détails et qui contient aussi ses dépendances imbriquées pour un accès itérable facile.</para>
  341. </sect2>
  342. </sect1>