Zend_Soap_AutoDiscovery.xml 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.soap.autodiscovery">
  5. <title>AutoDiscovery</title>
  6. <sect2 id="zend.soap.autodiscovery.introduction">
  7. <title>AutoDiscovery Einführung</title>
  8. <para>
  9. Die SOAP Funktionalität die im Zend Framework implementiert ist, ist dazu gedacht alle
  10. benötigten Schritte für die SOAP Kommunikation einfacher zu gestalten.
  11. </para>
  12. <para>
  13. SOAP ist ein von der Sprache unabhängiges Protokoll. Deshalb kann es nicht nur für
  14. PHP-zu-PHP Kommunikation verwendet werden.
  15. </para>
  16. <para>
  17. Es gibt drei Konfigurationen für SOAP Anwendungen wo Zend Framework verwendet werden
  18. kann:
  19. <orderedlist>
  20. <listitem>
  21. <simpara>
  22. SOAP Server PHP Anwendung &lt;---&gt; SOAP Client PHP Anwendung
  23. </simpara>
  24. </listitem>
  25. <listitem>
  26. <simpara>
  27. SOAP Server nicht-PHP Anwendung &lt;---&gt; SOAP Client PHP Anwendung
  28. </simpara>
  29. </listitem>
  30. <listitem>
  31. <simpara>
  32. SOAP Server PHP Anwendung &lt;---&gt; SOAP Client nicht-PHP Anwendung
  33. </simpara>
  34. </listitem>
  35. </orderedlist>
  36. </para>
  37. <para>
  38. Wir müssen immer wissen, welche Funktionalität vom SOAP Server angeboten wird um mit Ihm
  39. zu arbeiten. <ulink url="http://www.w3.org/TR/wsdl">WSDL</ulink> wird verwendet um die
  40. Netzwerk Service API im Detail zu beschreiben.
  41. </para>
  42. <para>
  43. Die WSDL Sprache ist komplex genug (siehe <ulink
  44. url="http://www.w3.org/TR/wsdl">http://www.w3.org/TR/wsdl</ulink> für die Details).
  45. Es ist also kompliziert genug die richtige WSDL Beschreibung vorzubereiten.
  46. </para>
  47. <para>
  48. Ein anderes Problem ist die Synchronisation von Änderungen in der Netzwerk Service API
  49. mit schon existierendem WSDL.
  50. </para>
  51. <para>
  52. Aber dieses Problem kann durch WSDL Autogeneration gelöst werden. Eine Vorbedingung
  53. dafür ist ein SOAP Server Autodiscovery. Es erzeugt ein Objekt ähnlich dem Objekt das in
  54. der SOAP Server Anwendung verwendet wird, extrahiert notwendige Informationen und
  55. erzeugt ein korrektes WSDL indem es die Information verwendet.
  56. </para>
  57. <para>
  58. Es gibt zwei Wege für die Verwendung des Zend Framworks für SOAP Server Anwendungen:
  59. <itemizedlist>
  60. <listitem>
  61. <para>Verwendung von eigenen Klassen.</para>
  62. </listitem>
  63. <listitem>
  64. <para>Verwendung eines Sets von Funktionen</para>
  65. </listitem>
  66. </itemizedlist>
  67. </para>
  68. <para>
  69. Beide Methoden werden von der Zend Framework Autodiscovery Funktionalität unterstützt.
  70. </para>
  71. <para>
  72. Die <classname>Zend_Soap_AutoDiscovery</classname> Klasse unterstützt auch das Mapping
  73. von Datentypen von PHP zu <ulink url="http://www.w3.org/TR/xmlschema-2/">XSD
  74. Typen</ulink>.
  75. </para>
  76. <para>
  77. Hier ist ein Beispiel einer üblichen Verwendung der Autodiscovery Funktionalität. Die
  78. Funktion <code>handle()</code> erzeugt die WSDL Datei und postet Sie an den Browser.
  79. <programlisting language="php"><![CDATA[
  80. class My_SoapServer_Class {
  81. ...
  82. }
  83. $autodiscover = new Zend_Soap_AutoDiscover();
  84. $autodiscover->setClass('My_SoapServer_Class');
  85. $autodiscover->handle();
  86. ]]></programlisting>
  87. </para>
  88. <para>
  89. Wenn man auf die erzeugte WSDL Datei zugreifen muß um Sie in eine Datei oder als XML
  90. String abzuspeichern, kann man die Funktionen <code>dump($filename)</code> oder
  91. <code>toXml()</code> verwenden die die AutoDiscovery Klasse anbietet.
  92. </para>
  93. <note id="zend.soap.autodiscovery.introduction.noserver">
  94. <title>Zend_Soap_Autodiscover ist kein Soap Server</title>
  95. <para>
  96. Es ist wichtig anzumerken, das die Klasse
  97. <classname>Zend_Soap_Autodiscover</classname> nicht für sich selbst als SOAP Server
  98. agiert. Sie erzeugt nur den WSDL und bietet Ihn jedem an der auf die URL zugreift
  99. auf die geschaut wird.
  100. </para>
  101. <para>
  102. Als Endpunkt der SOAP URI verwendet es den Standard
  103. <code>'http://' .$_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME']</code>, der aber
  104. mit der <code>setUri()</code> Funktion oder dem Contructor Parameter der
  105. <classname>Zend_Soap_AutoDiscover</classname> Klasse verändert werden kann. Der
  106. Endpunkt muß an einen <classname>Zend_Soap_Server</classname> übergeben werden der
  107. auf die Anfragen hört.
  108. </para>
  109. <para>
  110. <programlisting language="php"><![CDATA[
  111. if(isset($_GET['wsdl'])) {
  112. $autodiscover = new Zend_Soap_AutoDiscover();
  113. $autodiscover->setClass('HelloWorldService');
  114. $autodiscover->handle();
  115. } else {
  116. // zeigt auf diese aktuelle Datei
  117. $soap = new Zend_Soap_Server("http://example.com/soap.php?wsdl");
  118. $soap->setClass('HelloWorldService');
  119. $soap->handle();
  120. }
  121. ]]></programlisting>
  122. </para>
  123. </note>
  124. </sect2>
  125. <sect2 id="zend.soap.autodiscovery.class">
  126. <title>Automatische Erkennung von Klassen</title>
  127. <para>
  128. Wenn eine Klasse verwendet wird um SOAP Server Funktionalitäten anzubieten, dann sollte
  129. die selbe Klasse an <classname>Zend_Soap_AutoDiscover</classname> für die WSDL Erzeugung
  130. übergeben werden:
  131. <programlisting language="php"><![CDATA[
  132. $autodiscover = new Zend_Soap_AutoDiscover();
  133. $autodiscover->setClass('My_SoapServer_Class');
  134. $autodiscover->handle();
  135. ]]></programlisting>
  136. </para>
  137. <para>
  138. Die folgenden Regeln werden wärend der WSDL Erzeugung verwendet:
  139. <itemizedlist>
  140. <listitem>
  141. <para>Erzeugtes WSDL beschreibt einen RPC srtigen Web Service.</para>
  142. </listitem>
  143. <listitem>
  144. <para>
  145. Klassen Namen werden als Name des Web Services verwendet der beschrieben
  146. wird.
  147. </para>
  148. </listitem>
  149. <listitem>
  150. <para>
  151. <code>'http://' .$_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME']</code>
  152. wird als URI verwendet wenn das WSDL standardmäßig vorhanden ist und kann
  153. über die <code>setUri()</code> Methode überschrieben werden.
  154. </para>
  155. <para>
  156. Es wird auch als Ziel Namespace für alle Service bezogenen Namen verwendet
  157. (inklusive der beschriebenen komplexen Typen).
  158. </para>
  159. </listitem>
  160. <listitem>
  161. <para>
  162. Klassen Methoden werden in einen <ulink
  163. url="http://www.w3.org/TR/wsdl#_porttypes">Port Typ</ulink> übernommen.
  164. </para>
  165. <para>
  166. <code>$className . 'Port'</code> wird als Port Typ Name verwendet.
  167. </para>
  168. </listitem>
  169. <listitem>
  170. <para>
  171. Jede Klassen Methode wird als korrespondierende Port Operation registriert.
  172. </para>
  173. </listitem>
  174. <listitem>
  175. <para>
  176. Jeder Methoden Prototyp erzeugt korrespondierende Anfrage/Antwort
  177. Nachrichten.
  178. </para>
  179. <para>
  180. Eine Methode kann verschiedene Prototypen haben wenn einige Parameter der
  181. Methode optional sind.
  182. </para>
  183. </listitem>
  184. </itemizedlist>
  185. </para>
  186. <note>
  187. <title>Wichtig!</title>
  188. <para>
  189. WSDL Autodiscovery verwendet PHP Docblocks die vom Entwickler angeboten werden um
  190. die Parameter und Return Typen zu erkennen. Faktisch ist das, für skalare Typen, der
  191. einzige Weg um die Parameter Typen zu erkennen und für Return Typen ist das der
  192. einzige Weg um Sie zu erkennen.
  193. </para>
  194. <para>
  195. Das bedeutet, das Anbieten von richtigen und komplett detailierten Docblocks ist
  196. nicht nur beste Praxis, sondern wird für das erkunden der Klasse benötigt.
  197. </para>
  198. </note>
  199. </sect2>
  200. <sect2 id="zend.soap.autodiscovery.functions">
  201. <title>Funktionen für Autodiscovery</title>
  202. <para>
  203. Wenn ein Set von Funktionen verwendet wird um SOAP Server Funktionalität anzubieten,
  204. dann sollte das selbe Set mit <classname>Zend_Soap_AutoDiscovery</classname> für die
  205. WSDL Erzeugung verwendet werden:
  206. <programlisting language="php"><![CDATA[
  207. $autodiscover = new Zend_Soap_AutoDiscover();
  208. $autodiscover->addFunction('function1');
  209. $autodiscover->addFunction('function2');
  210. $autodiscover->addFunction('function3');
  211. ...
  212. $autodiscover->handle();
  213. ]]></programlisting>
  214. </para>
  215. <para>
  216. Die folgenden Regeln werden wärend der WSDL Erzeugung verwendet:
  217. <itemizedlist>
  218. <listitem>
  219. <para>Ein erstelltes WSDL beschreibt einen RPC artigen Web Service.</para>
  220. </listitem>
  221. <listitem>
  222. <para>
  223. Der aktuelle Skriptname wird als Name des Web Services verwendet der
  224. beschrieben wird.
  225. </para>
  226. </listitem>
  227. <listitem>
  228. <para>
  229. <code>'http://' .$_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME']</code>
  230. wird als URI verwendet wo WSDL vorhanden ist.
  231. </para>
  232. <para>
  233. Wird als Ziel Namespace für alle Service bezogenen Namen verwendet
  234. (inklusive der beschriebenen komplexen Typen).
  235. </para>
  236. </listitem>
  237. <listitem>
  238. <para>
  239. Funktionen werden in einem <ulink
  240. url="http://www.w3.org/TR/wsdl#_porttypes">Port Typ</ulink> verbunden.
  241. </para>
  242. <para>
  243. <code>$functionName . 'Port'</code> wird als Port Typ Name verwendet.
  244. </para>
  245. </listitem>
  246. <listitem>
  247. <para>
  248. Jede Funktion wird als korrespondierende Port Operation registriert.
  249. </para>
  250. </listitem>
  251. <listitem>
  252. <para>
  253. Jeder Funktions Prototyp erzeugt eine korrespondierende Anfrage/Antwort
  254. Nachricht.
  255. </para>
  256. <para>
  257. Funktionen können verschiedene Prototypen haben wenn einige Parameter der
  258. Methode optional sind.
  259. </para>
  260. </listitem>
  261. </itemizedlist>
  262. </para>
  263. <note>
  264. <title>Wichtig!</title>
  265. <para>
  266. WSDL Autodiscovery verwendet PHP Docblocks die vom Entwickler angeboten werden um
  267. die Parameter und Return Typen zu erkennen. Faktisch ist das, für skalare Typen, der
  268. einzige Weg um die Parameter Typen zu erkennen und für Return Typen ist das der
  269. einzige Weg um Sie zu erkennen.
  270. </para>
  271. <para>
  272. Das bedeutet, das Anbieten von richtigen und komplett detailierten Docblocks ist
  273. nicht nur beste Praxis, sondern wird für das erkunden der Klasse benötigt.
  274. </para>
  275. </note>
  276. </sect2>
  277. <sect2 id="zend.soap.autodiscovery.datatypes">
  278. <title>Automatische Erkennung. Datentypen</title>
  279. <para>
  280. Eingabe/Ausgabe Datentypen werden in Netzwerk Service Typen konvertiert indem das
  281. folgende Mapping verwendet wird:
  282. <itemizedlist>
  283. <listitem>
  284. <para>PHP Strings &lt;-&gt; <code>xsd:string</code>.</para>
  285. </listitem>
  286. <listitem>
  287. <para>PHP Integer &lt;-&gt; <code>xsd:int</code>.</para>
  288. </listitem>
  289. <listitem>
  290. <para>PHP Float und Double &lt;-&gt; <code>xsd:float</code>.</para>
  291. </listitem>
  292. <listitem>
  293. <para>PHP Boolean &lt;-&gt; <code>xsd:boolean</code>.</para>
  294. </listitem>
  295. <listitem>
  296. <para>PHP Arrays &lt;-&gt; <code>soap-enc:Array</code>.</para>
  297. </listitem>
  298. <listitem>
  299. <para>PHP Objekt &lt;-&gt; <code>xsd:struct</code>.</para>
  300. </listitem>
  301. <listitem>
  302. <para>
  303. PHP Klasse &lt;-&gt; basierend auf der Strategie der komplexen Typen (See:
  304. <xref linkend="zend.soap.wsdl.types.add_complex" />)
  305. <footnote>
  306. <para>
  307. <classname>Zend_Soap_AutoDiscover</classname> wird mit der
  308. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>
  309. Klasse als Erkennungsalgorithmus für komplexe Typen erstellt. Der
  310. erste Parameter des AutoDiscover Constructors nimmt jede Strategie
  311. für komplexe Typen die
  312. <classname>Zend_Soap_Wsdl_Strategy_Interface</classname>
  313. implementieren oder einen String mit dem Nmaen der Klasse. Um
  314. Backwards Compatibility mit <code>$extractComplexType</code> zu
  315. gewährleisten werden boolsche Variablen wie in
  316. <classname>Zend_Soap_Wsdl</classname> geparst. Siehe das <link
  317. linkend="zend.soap.wsdl.types.add_complex"><classname>Zend_Soap_Wsdl</classname>
  318. Manual über das Hinzufügen von komplexen</link> Typen für
  319. weitere Informationen.
  320. </para>
  321. </footnote>.
  322. </para>
  323. </listitem>
  324. <listitem>
  325. <para>
  326. type[] oder object[] (z.B. int[]) &lt;-&gt; basieren auf der Strategie der
  327. komplexen Typen
  328. </para>
  329. </listitem>
  330. <listitem>
  331. <para>PHP Void &lt;-&gt; Leerer Typ.</para>
  332. </listitem>
  333. <listitem>
  334. <para>Wenn der Typ aus irgendeinem Grund keinem dieser Typen entspricht, dann
  335. wird <code>xsd:anyType</code> verwendet.</para>
  336. </listitem>
  337. </itemizedlist>
  338. Wo <code>xsd:</code> ein "http://www.w3.org/2001/XMLSchema" Namespace ist, ist
  339. <code>soap-enc:</code> ein "http://schemas.xmlsoap.org/soap/encoding/" Namespace, und
  340. <code>tns:</code> ist ein "Ziel Namespace" für einen Service.
  341. </para>
  342. </sect2>
  343. <sect2 id="zend.soap.autodiscovery.wsdlstyles">
  344. <title>Stile für das Binden von WSDL</title>
  345. <para>
  346. WSDL bietet verschiedene Transport Mechanismen und Stile. Das beeinträchtigt die
  347. <code>soap:binding</code> und <code>soap:body</code> Tags in der Binding Sektion von
  348. WSDL. Unterschiedliche Clients haben unterschiedliche Anforderungen wie diese Optionen
  349. wirklich arbeiten. Hierfür kann man die Stile setzen bevor man eine
  350. <code>setClass</code> oder <code>addFunction</code> Methode auf der AutoDiscovery Klasse
  351. ausführt.
  352. </para>
  353. <para>
  354. <programlisting language="php"><![CDATA[
  355. $autodiscover = new Zend_Soap_AutoDiscover();
  356. // Standard ist 'use' => 'encoded' und
  357. // 'encodingStyle' => 'http://schemas.xmlsoap.org/soap/encoding/'
  358. $autodiscover->setOperationBodyStyle(
  359. array('use' => 'literal',
  360. 'namespace' => 'http://framework.zend.com')
  361. );
  362. // Standard ist 'style' => 'rpc' und
  363. // 'transport' => 'http://schemas.xmlsoap.org/soap/http'
  364. $autodiscover->setBindingStyle(
  365. array('style' => 'document',
  366. 'transport' => 'http://framework.zend.com')
  367. );
  368. ...
  369. $autodiscover->addFunction('myfunc1');
  370. $autodiscover->handle();
  371. ]]></programlisting>
  372. </para>
  373. </sect2>
  374. </sect1>