Zend_Soap_Wsdl.xml 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.soap.wsdl">
  5. <title>WSDL Zugriffsmethoden</title>
  6. <note>
  7. <para>
  8. Die <classname>Zend_Soap_Wsdl</classname> Klasse wird von der
  9. <classname>Zend_Soap_Server</classname> Komponente intern verwendet um mit WSDL
  10. Dokumenten zu arbeiten. Trotzdem könnte man die Funktionalität die von dieser Klasse
  11. angeboten wird auch für eigene Zwecke verwendet werden. Das
  12. <classname>Zend_Soap_Wsdl</classname> Paket enthält sowohl einen Parser als auch einen
  13. Ersteller für WSDL Dokumente.
  14. </para>
  15. <para>
  16. Wenn man nicht plant das zu tun, kann dieses Kapitel der Dokumentation übersprungen
  17. werden.
  18. </para>
  19. </note>
  20. <sect2 id="zend.soap.wsdl.constructor">
  21. <title>Zend_Soap_Wsdl Konstruktor</title>
  22. <para>
  23. Der <classname>Zend_Soap_Wsdl</classname> Konstruktor nimmt drei Parameter:
  24. <orderedlist>
  25. <listitem>
  26. <simpara>
  27. <varname>$name</varname> - Name des Web Services der beschrieben wird.
  28. </simpara>
  29. </listitem>
  30. <listitem>
  31. <simpara>
  32. <varname>$uri</varname> - <acronym>URI</acronym> wo das WSDL vorhanden sein
  33. wird (könnte auch eine Referenz zu einer Datei auf dem Dateisystem sein).
  34. </simpara>
  35. </listitem>
  36. <listitem>
  37. <simpara>
  38. <varname>$strategy</varname> - Optionales Flag das verwendet wird um die
  39. Strategie für die Erkennung von komplexen Typen (Objekte) zu identifizieren.
  40. Das war vor der Version 1.7 ein boolscher
  41. <varname>$extractComplexTypes</varname> und kann aus Gründen der
  42. Rückwärtskompatibilität noch immer als Boolean gesetzt werden. Standardmäßig
  43. ist das Erkennungsverhalten von 1.6 gesetzt. Um mit Strategien für komplexe
  44. Typenerkennung weiterzumachen lesen wie weiter im Kapitel: <link
  45. linkend="zend.soap.wsdl.types.add_complex">Komplexe Typen
  46. hinzufügen</link>.
  47. </simpara>
  48. </listitem>
  49. </orderedlist>
  50. </para>
  51. </sect2>
  52. <sect2 id="zend.soap.wsdl.addmessage">
  53. <title>Die addMessage() Methode</title>
  54. <para>
  55. Die <methodname>addMessage($name, $parts)</methodname> Methode fügt eine neue
  56. Nachrichten Beschreibung zu einem WSDL Dokumetn hinzu (/definitions/message Element).
  57. </para>
  58. <para>
  59. Jede Nachricht korrespondiert zu einer Methode im Sinne von
  60. <classname>Zend_Soap_Server</classname> und <classname>Zend_Soap_Client</classname>
  61. Funktionalität.
  62. </para>
  63. <para>
  64. Der <varname>$name</varname> Parameter repräsentiert den Namen der Nachricht.
  65. </para>
  66. <para>
  67. Der <varname>$parts</varname> Parameter ist ein Array von Nachrichten Teilen welche
  68. <acronym>SOAP</acronym> Aufruf Parameter beschreiben. Es ist ein assoziatives Array:
  69. 'part name' (SOAP Aufruf Parameter Name) =&gt; 'part type'.
  70. </para>
  71. <para>
  72. Das Typ Mapping Management wird durchgeführt indem die
  73. <methodname>addTypes()</methodname>, <methodname>addTypes()</methodname> und
  74. <methodname>addComplexType()</methodname> Methoden ausgeführt werden (siehe anbei).
  75. </para>
  76. <note>
  77. <para>
  78. Nachrichten Teile können entweder 'element' oder 'type' Attribute für das typisieren
  79. verwenden (siehe <ulink url="http://www.w3.org/TR/wsdl#_messages"/>).
  80. </para>
  81. <para>
  82. 'element' Attribute müssen zu einem entsprechenden Element von Daten Typ Definition
  83. referieren. 'type' zu einem entsprechenden complexType Eintrag.
  84. </para>
  85. <para>
  86. Alle standardmäßigen XSD Typen haben beide 'element' und 'complexType' Definitionen
  87. (siehe <ulink url="http://schemas.xmlsoap.org/soap/encoding/"/>).
  88. </para>
  89. <para>
  90. Alle nicht-standardmäßigen Typen, welche hinzugefügt werden können durch verwenden
  91. der <methodname>Zend_Soap_Wsdl::addComplexType()</methodname> Methode, sind
  92. beschrieben durch Verwendung des 'complexType' Nodes des
  93. '/definitions/types/schema/' Abschnitts des WSDL Dokuments.
  94. </para>
  95. <para>
  96. <methodname>addMessage()</methodname> Methoden verwenden also immer das 'type'
  97. Attribut um Typen zu beschreiben.
  98. </para>
  99. </note>
  100. </sect2>
  101. <sect2 id="zend.soap.wsdl.add_port_type">
  102. <title>Die addPortType() Methode</title>
  103. <para>
  104. Die <methodname>addPortType($name)</methodname> Methode fügt neue Port Typen zu einem
  105. WSDL Dokument (/definitions/portType) mit dem spezifizierten Port Typ Namen hinzu.
  106. </para>
  107. <para>
  108. Es verbindet ein Set von Web Service Methoden die im Sinne der
  109. <classname>Zend_Soap_Server</classname> Implementation definiert sind.
  110. </para>
  111. <para>
  112. Siehe <ulink url="http://www.w3.org/TR/wsdl#_porttypes"/> für Details.
  113. </para>
  114. </sect2>
  115. <sect2 id="zend.soap.wsdl.add_port_operation">
  116. <title>Die addPortOperation() Methode</title>
  117. <para>
  118. Die <code>addPortOperation($portType, $name, $input = false, $output = false, $fault =
  119. false)</code> Methode fügt eine neue Port Operation zum spezifizierten Port Typ des
  120. WSDL Dokuments hinzu (/definitions/portType/operation).
  121. </para>
  122. <para>
  123. Jede Port Operation korrespondiert zu einer Methode der Klasse (wenn der Web Service auf
  124. einer Klasse basiert) oder Funktion (wenn der Web Service auf einem Set von Methoden
  125. basiert) im Sinne der <classname>Zend_Soap_Server</classname> Implementation.
  126. </para>
  127. <para>
  128. Sie fügt auch eine korrespondierende Port Operations Nachricht hinzu anhängig von den
  129. spezifizierten <varname>$input</varname>, <varname>$output</varname> und
  130. <varname>$fault</varname> Parametern.
  131. <note>
  132. <para>
  133. Die <classname>Zend_Soap_Server</classname> Komponente erzeugt zwei Nachrichten
  134. für jede Port Operation während das Service das auf der
  135. <classname>Zend_Soap_Server</classname> Klasse basiert beschrieben wird:
  136. <itemizedlist>
  137. <listitem>
  138. <para>
  139. Eine Eingabe Nachricht mit dem Namen <code>$methodName .
  140. 'Request'</code>.
  141. </para>
  142. </listitem>
  143. <listitem>
  144. <para>
  145. Eine Ausgabe Nachricht mit dem Namen <code>$methodName .
  146. 'Response'</code>.
  147. </para>
  148. </listitem>
  149. </itemizedlist>
  150. </para>
  151. </note>
  152. </para>
  153. <para>
  154. Siehe <ulink url="http://www.w3.org/TR/wsdl#_request-response"/> für Details.
  155. </para>
  156. </sect2>
  157. <sect2 id="zend.soap.wsdl.add_binding">
  158. <title>Die addBinding() Methode</title>
  159. <para>
  160. Die <methodname>addBinding($name, $portType)</methodname> Methode fügt neue Bindungen in
  161. das WSDL Dokument ein (/definitions/binding).
  162. </para>
  163. <para>
  164. Der 'binding' WSDL Dokument Knoten definiert das Nachrichtenformat und Protokolldetails
  165. für Operationen und Nachrichten die von einem speziellen portType definiert sind
  166. (siehe <ulink url="http://www.w3.org/TR/wsdl#_bindings"/>).
  167. </para>
  168. <para>
  169. Die Methode erzeugt einen Bindungsknoten und gibt diesen zurück. Dieser kann dann
  170. verwendet werden um mit aktuellen Daten gefüllt zu werden.
  171. </para>
  172. <para>
  173. Die <classname>Zend_Soap_Server</classname> Implementation verwendet den
  174. <code>$serviceName . 'Binding'</code> Namen für das 'binding' Element eines WSDL
  175. Dokuments.
  176. </para>
  177. </sect2>
  178. <sect2 id="zend.soap.wsdl.add_binding_operation">
  179. <title>Die addBindingOperation() Methode</title>
  180. <para>
  181. Die <code>addBindingOperation($binding, $name, $input = false, $output = false, $fault =
  182. false)</code> Methode fügt eine Operation zu einem gebundenen Element mit dem
  183. spezifizierten Namen hinzu (/definitions/binding/operation).
  184. </para>
  185. <para>
  186. Sie nimmt das <code>XML_Tree_Node</code> Objekt das von
  187. <methodname>addBinding()</methodname> zurückgegeben wird als Eingabe
  188. (<varname>$binding</varname> Parameter) um ein 'operation' Element mit
  189. Eingabe/Ausgabe/Falsch Einträgen hinzuzufügen abhängig von den spezifizierten
  190. Parametern.
  191. </para>
  192. <para>
  193. Die <classname>Zend_Soap_Server</classname> Implementation fügt korrespondierende
  194. gebundene Einträge für jede Web Service Methode mit Eingabe und Ausgabe Einträgen hinzu
  195. die ein 'soap:body' Element als '&lt;soap:body use="encoded"
  196. encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"/&gt; definieren.
  197. </para>
  198. <para>
  199. Siehe <ulink url="http://www.w3.org/TR/wsdl#_bindings"/> für Details.
  200. </para>
  201. </sect2>
  202. <sect2 id="zend.soap.wsdl.add_soap_binding">
  203. <title>Die addSoapBinding() Methode</title>
  204. <para>
  205. Die <code>addSoapBinding($binding, $style = 'document', $transport =
  206. 'http://schemas.xmlsoap.org/soap/http')</code> Methode fügt einen
  207. <acronym>SOAP</acronym> Bindung Eintrag ('soap:binding') zum Bindung Element (welches
  208. bereits zu einigen Port Typen verbunden ist) mit dem spezifizierten Stil und Transport
  209. hinzu (Die Zend_Soap_Server Implementation verwendet RPC Stil über
  210. <acronym>HTTP</acronym>).
  211. </para>
  212. <para>
  213. Das '/definitions/binding/soap:binding' Element wird verwendet um zu signieren dass das
  214. Bindung zum <acronym>SOAP</acronym> Protokoll Format gebunden ist.
  215. </para>
  216. <para>
  217. Siehe <ulink url="http://www.w3.org/TR/wsdl#_bindings"/> für Details.
  218. </para>
  219. </sect2>
  220. <sect2 id="zend.soap.wsdl.add_soap_operation">
  221. <title>Die addSoapOperation() Methode</title>
  222. <para>
  223. Die <methodname>addSoapOperation($binding, $soap_action)</methodname> Methode fügt einen
  224. <acronym>SOAP</acronym> Operations Eintrag ('soap:operation') zum Bindungs Element mit
  225. den spezifizierten Aktionen hinzu. Das 'style' Attribut des 'soap:operation' Elements
  226. wird nicht verwendet seit das Programmier Modell (RPC-orientiert oder
  227. Dokument-orientiert) die <methodname>addSoapBinding()</methodname> Methode verwenden
  228. kann.
  229. </para>
  230. <para>
  231. Das 'soapAction' Attribut des '/definitions/binding/soap:operation' Elements
  232. spezifiziert den Wert des <acronym>SOAP</acronym>Action Headers für diese Operation.
  233. Dieses Attribut wird für <acronym>SOAP</acronym> über <acronym>HTTP</acronym> benötigt
  234. und <emphasis>darf in keinem Fall</emphasis> für andere Transporte spezifiziert werden.
  235. </para>
  236. <para>
  237. Die <classname>Zend_Soap_Server</classname> Implementation verwendet
  238. <code>$serviceUri . '#' . $methodName</code> für den <acronym>SOAP</acronym> Operations
  239. Action Namen.
  240. </para>
  241. <para>
  242. Siehe <ulink url="http://www.w3.org/TR/wsdl#_soap:operation"/> für Details.
  243. </para>
  244. </sect2>
  245. <sect2 id="zend.soap.wsdl.add_service">
  246. <title>Die addService() Methode</title>
  247. <para>
  248. Die <methodname>addService($name, $port_name, $binding, $location)</methodname> Methode
  249. fügt dem WSDL Dokument ein '/definitions/service' Element mit dem spezifizierten Web
  250. Service Namen, Port Namen, Bindung und Ort hinzu.
  251. </para>
  252. <para>
  253. WSDL 1.1 erlaubt es verschiedene Port Typen pro Service zu haben (Sets von Operationen).
  254. Diese Fähigkeit wird von der <classname>Zend_Soap_Server</classname> Implementation
  255. nicht verwendet und von der <classname>Zend_Soap_Wsdl</classname> Klasse nicht
  256. unterstützt.
  257. </para>
  258. <para>
  259. Die <classname>Zend_Soap_Server</classname> Implementation verwendet:
  260. <itemizedlist>
  261. <listitem>
  262. <para>
  263. <code>$name . 'Service'</code> als Name des Web Services,
  264. </para>
  265. </listitem>
  266. <listitem>
  267. <para>
  268. <code>$name . 'Port'</code> als Name des Port Typs,
  269. </para>
  270. </listitem>
  271. <listitem>
  272. <para>
  273. <code>'tns:' . $name . 'Binding'</code>
  274. <footnote>
  275. <para>
  276. <code>'tns:' namespace</code> wird als Skript
  277. <acronym>URI</acronym> definiert
  278. (<code>'http://' .$_SERVER['HTTP_HOST'] .
  279. $_SERVER['SCRIPT_NAME']</code>).
  280. </para>
  281. </footnote>
  282. als Bindungs Name,
  283. </para>
  284. </listitem>
  285. <listitem>
  286. <para>
  287. Die Skript <acronym>URI</acronym><footnote><para><code>'http://'
  288. .$_SERVER['HTTP_HOST'] .
  289. $_SERVER['SCRIPT_NAME']</code></para></footnote> als eine Service URI
  290. für die Web Service Definition bei Verwendung von Klassen.
  291. </para>
  292. </listitem>
  293. </itemizedlist>
  294. wobei <varname>$name</varname> der Klassenname für die Web Service Definition ist wenn
  295. Klassen verwendet werden und Skript Name für die Web Service Definition wenn ein Set von
  296. Funktionen verwendet wird.
  297. </para>
  298. <para>
  299. Siehe <ulink url="http://www.w3.org/TR/wsdl#_services"/> für Details.
  300. </para>
  301. </sect2>
  302. <sect2 id="zend.soap.wsdl.types">
  303. <title>Typ Entsprechung</title>
  304. <para>
  305. Die <classname>Zend_Soap</classname> WSDL Implementation der Zugriffsmethoden verwendet
  306. die folgenden Typ Entsprechungen zwischen <acronym>PHP</acronym> und
  307. <acronym>SOAP</acronym> Typen:
  308. <itemizedlist>
  309. <listitem>
  310. <para><acronym>PHP</acronym> Strings &lt;-&gt; <code>xsd:string</code>.</para>
  311. </listitem>
  312. <listitem>
  313. <para><acronym>PHP</acronym> Integer &lt;-&gt; <code>xsd:int</code>.</para>
  314. </listitem>
  315. <listitem>
  316. <para>
  317. <acronym>PHP</acronym> Float (Fliesskomma) und Double &lt;-&gt;
  318. <code>xsd:float</code>.
  319. </para>
  320. </listitem>
  321. <listitem>
  322. <para><acronym>PHP</acronym> Boolean &lt;-&gt; <code>xsd:boolean</code>.</para>
  323. </listitem>
  324. <listitem>
  325. <para><acronym>PHP</acronym> Arrays &lt;-&gt; <code>soap-enc:Array</code>.</para>
  326. </listitem>
  327. <listitem>
  328. <para><acronym>PHP</acronym> Objekt &lt;-&gt; <code>xsd:struct</code>.</para>
  329. </listitem>
  330. <listitem>
  331. <para>
  332. <acronym>PHP</acronym> Klasse &lt;-&gt; basierend auf der Strategie der
  333. komplexen Typen (Siehe: <link
  334. linkend="zend.soap.wsdl.types.add_complex">diesen Abschnitt</link>)
  335. <footnote>
  336. <para>
  337. Standardmäßig wird <classname>Zend_Soap_Wsdl</classname> mit der
  338. Klasse
  339. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>
  340. als Erkennungsalgorithmus für komplexe Typen erstellt. Der erste
  341. Parameter des AutoDiscover Constructors nimmt jede Strategie für
  342. komplexe Typen die
  343. <classname>Zend_Soap_Wsdl_Strategy_Interface</classname>
  344. implementiert oder einen String mit dem Namen dieser Klasse. Für
  345. Rückwärtskompatibilität mit den dem Boolean
  346. <varname>$extractComplexType</varname> werden Variablen auf dem
  347. folgenden Weg geparst: Bei <constant>TRUE</constant>, wird
  348. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>
  349. verwendet, und bei <constant>FALSE</constant>
  350. <classname>Zend_Soap_Wsdl_Strategy_AnyType</classname>.
  351. </para>
  352. </footnote>.
  353. </para>
  354. </listitem>
  355. <listitem>
  356. <para>PHP Void &lt;-&gt; Leerer Typ.</para>
  357. </listitem>
  358. <listitem>
  359. <para>Wenn der Typ auf irgendeinem Grund zu keinem dieser Typen passt, dann wird
  360. <code>xsd:anyType</code> verwendet.</para>
  361. </listitem>
  362. </itemizedlist>
  363. Wo <code>xsd:</code> ein "http://www.w3.org/2001/XMLSchema" Namespace ist, ist
  364. <code>soap-enc:</code> ein "http://schemas.xmlsoap.org/soap/encoding/" Namespace,
  365. und <code>tns:</code> ist ein "Ziel Namespace" für das Service.
  366. </para>
  367. <sect3 id="zend.soap.wsdl.types.retrieve">
  368. <title>Empfangen von Typ Informationen</title>
  369. <para>
  370. Die <methodname>getType($type)</methodname> Methode kann verwendet werden um ein
  371. Mapping für einen spezifizierten <acronym>PHP</acronym> Typ zu erhalten:
  372. </para>
  373. <programlisting language="php"><![CDATA[
  374. ...
  375. $wsdl = new Zend_Soap_Wsdl('My_Web_Service', $myWebServiceUri);
  376. ...
  377. $soapIntType = $wsdl->getType('int');
  378. ...
  379. class MyClass {
  380. ...
  381. }
  382. ...
  383. $soapMyClassType = $wsdl->getType('MyClass');
  384. ]]></programlisting>
  385. </sect3>
  386. <sect3 id="zend.soap.wsdl.types.add_complex">
  387. <title>Hinzufügen komplexer Typ Informationen</title>
  388. <para>
  389. Die <methodname>addComplexType($type)</methodname> Methode wird verwendet um
  390. komplexe Typen (PHP Klassen) zu einem WSDL Dokument hinzuzufügen.
  391. </para>
  392. <para>
  393. Es wird automatisch von der <methodname>getType()</methodname> Methode verwendet und
  394. fügt einen korrespondierenden komplexen Typen von Methodenparametern oder
  395. Rückgabetypen hinzu.
  396. </para>
  397. <para>
  398. Der Algorithmus für das Erkennen und Aufbauen basiert auf der aktuellen Strategie
  399. für die aktive Erkennung von komplexen Typen. Man kann die Strategie für die
  400. Erkennung setzen indem entweder der Klassenname as String spezifiziert wird, oder
  401. indem eine Instanz einer <classname>Zend_Soap_Wsdl_Strategy_Interface</classname>
  402. Implementation als dritter Parameter des Konstruktors verwendet wird, oder indem die
  403. <methodname>setComplexTypeStrategy($strategy)</methodname> Funktion von
  404. <classname>Zend_Soap_Wsdl</classname> verwendet wird. Die folgenden Strategien für
  405. die Erkennung existieren aktuell:
  406. </para>
  407. <itemizedlist>
  408. <listitem>
  409. <para>
  410. Klasse <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>:
  411. Standardmäßig aktiviert (wenn dem Konstruktor kein dritter Parameter gesetzt
  412. wird). Er iteriert über die öffentlichen Attribute eines Klassentyps und
  413. registriert Sie als Untertypen des komplexen Objekttyps.
  414. </para>
  415. </listitem>
  416. <listitem>
  417. <para>
  418. Klasse <classname>Zend_Soap_Wsdl_Strategy_AnyType</classname>: Castet alle
  419. komplexen Typen in einen einfachen XSD Typ xsd:anyType. Vorsicht ist
  420. angeraten da diese Abkürzung für die Erkennung von komplexen Typen kann
  421. warscheinlich nur von lose typisierten Sprachen wie <acronym>PHP</acronym>
  422. erfolgreich behandelt werden.
  423. </para>
  424. </listitem>
  425. <listitem>
  426. <para>
  427. Klasse <classname>Zend_Soap_Wsdl_Strategy_ArrayOfTypeSequence</classname>:
  428. Diese Strategie erlaubt es die Rückgabeparameter mit diesen Typen zu
  429. spezifizieren: <code>int[]</code> oder <code>string[]</code>. Ab dem Zend
  430. Framework Version 1.9 können beide, sowohl einfache <acronym>PHP</acronym>
  431. Typen wie Int, String, Boolean, Float sowie Objekte und Arrays von Objekten
  432. behandelt werden.
  433. </para>
  434. </listitem>
  435. <listitem>
  436. <para>
  437. Klasse <classname>Zend_Soap_Wsdl_Strategy_ArrayOfTypeComplex</classname>:
  438. Diese Strategie erlaubt die Erkennung von sehr komplexen Arrays von
  439. Objekten. Objekttypen werden basierend auf
  440. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname> erkannt
  441. und ein Array wird um diese Definition gewrappt.
  442. </para>
  443. </listitem>
  444. <listitem>
  445. <para>
  446. Klasse <classname>Zend_Soap_Wsdl_Strategy_Composite</classname>: Diese
  447. Strategie kann alle Strategien kombinieren indem <acronym>PHP</acronym>
  448. komplexe Typen (Klassennamen) zu der gewünschten Strategie über die
  449. <methodname>connectTypeToStrategy($type, $strategy)</methodname> Methode
  450. verbunden werden. Eine komplette Typemap kann dem Contructor als Array, mit
  451. <varname>$type</varname> -> <varname>$strategy</varname> Paaren angegeben
  452. werden. Der zweite Parameter spezifiziert die Standardstrategie die
  453. verwendet wird wenn ein unbekannter Typ hinzugefügt werden soll. Diese
  454. Parameter ist standardmäßig die
  455. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>
  456. Strategie.
  457. </para>
  458. </listitem>
  459. </itemizedlist>
  460. <para>
  461. Die <methodname>addComplexType()</methodname> Methode erstellt ein
  462. '/definitions/types/xsd:schema/xsd:complexType' Element für jeden beschriebenen
  463. komplexen Typen mit dem Namen der spezifizierten <acronym>PHP</acronym> Klasse.
  464. </para>
  465. <para>
  466. Die Klassen Eigenschaften <emphasis>MÜSSEN</emphasis> ein Docblock Kapitel mit den
  467. beschriebenen <acronym>PHP</acronym> Typen haben damit die Eigenschaft in die WSDL
  468. Beschreibung hinzugefügt wird.
  469. </para>
  470. <para>
  471. <methodname>addComplexType()</methodname> prüft ob der Typ bereits im Typ Kapitel
  472. des WSDL Dokuments beschrieben wird.
  473. </para>
  474. <para>
  475. Es verhindert Duplikate wenn diese Methode zwei oder mehrmals aufgerufen wird und
  476. auch Rekursionen im Kapitel der Typ Definitionen.
  477. </para>
  478. <para>
  479. Siehe <ulink url="http://www.w3.org/TR/wsdl#_types"/> für Details.
  480. </para>
  481. </sect3>
  482. </sect2>
  483. <sect2 id="zend.soap.wsdl.add_documentation">
  484. <title>Die addDocumentation() Methode</title>
  485. <para>
  486. Die <methodname>addDocumentation($input_node, $documentation)</methodname> Methode fügt
  487. menschlich lesbare Dokumentation hinzu indem das optionale 'wsdl:document' Element
  488. verwendet wird.
  489. </para>
  490. <para>
  491. Das '/definitions/binding/soap:binding' Element wird verwendet um zu signieren das die
  492. Bindung zum <acronym>SOAP</acronym> Protokoll Format gebunden wurde.
  493. </para>
  494. <para>
  495. Siehe <ulink url="http://www.w3.org/TR/wsdl#_documentation"/> für Details.
  496. </para>
  497. </sect2>
  498. <sect2 id="zend.soap.wsdl.retrieve">
  499. <title>Das endgültige WSDL Dokument erhalten</title>
  500. <para>
  501. Die <methodname>toXML()</methodname>, <methodname>toDomDocument()</methodname> und
  502. <code>dump($filename = false)</code> Methoden können verwendet werden um das WSDL
  503. Dokument als <acronym>XML</acronym>, DOM Struktur oder Datei zu erhalten.
  504. </para>
  505. </sect2>
  506. </sect1>