Zend_Json-Server.xml 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15807 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.json.server">
  5. <title>Zend_Json_Server - JSON-RPC server</title>
  6. <para>
  7. <classname>Zend_Json_Server</classname> ist eine
  8. <ulink url="http://groups.google.com/group/json-rpc/">JSON-RPC</ulink> Server
  9. Implementierung. Sie unterstützt sowohl <ulink
  10. url="http://json-rpc.org/wiki/specification">die Spezifikation von JSON-RPC Version
  11. 1</ulink> als auch die <ulink
  12. url="http://groups.google.com/group/json-rpc/web/json-rpc-1-2-proposal">Spezifikation
  13. der Version 2</ulink>; zusätzlich bietet Sie eine PHP Implementierung der <ulink
  14. url="http://groups.google.com/group/json-schema/web/service-mapping-description-proposal">Spezifikation
  15. für Service Mapping Description (SMD)</ulink> Um Kunden von Services deren Metadaten
  16. anzubieten.
  17. </para>
  18. <para>
  19. JSON-RPC ist ein leichgewichtiges Remoce Procedure Call Protokoll das JSON für seine
  20. Nachrichten verwendet. Diese JSON-RPC Implementierung folgt PHP's <ulink
  21. url="http://us.php.net/manual/en/function.soap-soapserver-construct.php">SoapServer</ulink>
  22. API. Das bedeutet das in einer typischen Situation einfach folgendes getan wird:
  23. </para>
  24. <itemizedlist>
  25. <listitem>
  26. <para>
  27. Instanzieren des Server Objekts
  28. </para>
  29. </listitem>
  30. <listitem>
  31. <para>
  32. Eine oder mehrere Funktionen und/oder Klassen/Objekte dem Server Objekt hinzufügen
  33. </para>
  34. </listitem>
  35. <listitem>
  36. <para>
  37. Die Anfrage mit handle() ausführen
  38. </para>
  39. </listitem>
  40. </itemizedlist>
  41. <para>
  42. <classname>Zend_Json_Server</classname> verwendet <xref linkend="zend.server.reflection" />
  43. um Reflektion durchzuführen um den SMD zu erstellen und die Signaturen der Methodenaufrufe
  44. zu erzwingen. Als solche, ist es zwingend notwendig das alle hinzugefügten Funktionen
  45. und/oder Klassenmethoden komplette PHP Docblocks dokumentiert haben mindestens aber:
  46. </para>
  47. <itemizedlist>
  48. <listitem>
  49. <para>
  50. Alle Parameter und deren erwarteter Variablentypen
  51. </para>
  52. </listitem>
  53. <listitem>
  54. <para>
  55. Den Variablentyp des Rückgabewertes
  56. </para>
  57. </listitem>
  58. </itemizedlist>
  59. <para>
  60. <classname>Zend_Json_Server</classname> hört aktuell nur auf POST Anfragen; glücklicherweise
  61. bieten die meisten JSON-RPC Client Implementierungen die zur aktuell vorhanden sind nur POST
  62. Anfragen. Das macht es einfach den gleichen Endpunkt des Servers so zu verwenden das er
  63. beide Anfragen behandelt sowie die Service SMD liefert, wie im nächsten Beispiel gezeigt.
  64. </para>
  65. <example id="zend.json.server.usage">
  66. <title>Zend_Json_Server Verwendung</title>
  67. <para>
  68. Zuerst müssen wir eine Klasse definieren die wir über den JSON-RPC Server ausliefern
  69. wollen. Wir nennen die Klasse 'Calculator', und definieren die Methoden 'add',
  70. 'substract', 'multiple', und 'divide':
  71. </para>
  72. <programlisting language="php"><![CDATA[
  73. /**
  74. * Calculator - Einfache Klasse zur Auslieferung über JSON-RPC
  75. */
  76. class Calculator
  77. {
  78. /**
  79. * Summe von zwei Variablen zurückgeben
  80. *
  81. * @param int $x
  82. * @param int $y
  83. * @return int
  84. */
  85. public function add($x, $y)
  86. {
  87. return $x + $y;
  88. }
  89. /**
  90. * Differenz von zwei Variablen zurückgeben
  91. *
  92. * @param int $x
  93. * @param int $y
  94. * @return int
  95. */
  96. public function subtract($x, $y)
  97. {
  98. return $x - $y;
  99. }
  100. /**
  101. * Produkt von zwei Variablen zurückgeben
  102. *
  103. * @param int $x
  104. * @param int $y
  105. * @return int
  106. */
  107. public function multiply($x, $y)
  108. {
  109. return $x * $y;
  110. }
  111. /**
  112. * Division von zwei Variablen zurückgeben
  113. *
  114. * @param int $x
  115. * @param int $y
  116. * @return float
  117. */
  118. public function divide($x, $y)
  119. {
  120. return $x / $y;
  121. }
  122. }
  123. ]]></programlisting>
  124. <para>
  125. Es ist zu beachten das jede Methode einen Docblock mit Einträgen besitzt die jeden
  126. Parameter und seinen Typ beschreiben, sowie einen Eintrag für den Rückgabewert. Das ist
  127. <emphasis>absolut kritisch</emphasis> wenn <classname>Zend_Json_Server</classname>
  128. verwendet wird -- oder auch jede andere Server Komponente für diesen Zweck im Zend
  129. Framework.
  130. </para>
  131. <para>
  132. Erstellen wir also ein Skript um die Anfrage zu behandeln:
  133. </para>
  134. <programlisting language="php"><![CDATA[
  135. $server = new Zend_Json_Server();
  136. // Zeigt welche Funktionalität vorhanden ist:
  137. $server->setClass('Calculator');
  138. // Behandelt die Anfrage:
  139. $server->handle();
  140. ]]></programlisting>
  141. <para>
  142. Trotzdem behandelt das noch immer nicht das Problem der Rückgabe eines SMD damit der
  143. JSON-RPC Client die Methoden selbstständig erkennen kann. Das kann getan werden indem
  144. die HTTP Anfragemethode erkannt wird, und anschließend einige Metadaten des Servers
  145. spezifiziert werden:
  146. </para>
  147. <programlisting language="php"><![CDATA[
  148. $server = new Zend_Json_Server();
  149. $server->setClass('Calculator');
  150. if ('GET' == $_SERVER['REQUEST_METHOD']) {
  151. // Zeigt den Endpunkt der URL, und die verwendete JSON-RPC Version:
  152. $server->setTarget('/json-rpc.php')
  153. ->setEnvelope(Zend_Json_Server_Smd::ENV_JSONRPC_2);
  154. // Den SMD holen
  155. $smd = $server->getServiceMap();
  156. // Den SMD an den Client zurückgeben
  157. header('Content-Type: application/json');
  158. echo $smd;
  159. return;
  160. }
  161. $server->handle();
  162. ]]></programlisting>
  163. <para>
  164. Wenn der JSON-RPC Server mit dem Dojo Toolkit verwendet wird muß auch ein spezielles
  165. Kompatibilitätsflag gesetzt werden um sicherzustellen das die zwei korrekt miteinander
  166. arbeiten:
  167. </para>
  168. <programlisting language="php"><![CDATA[
  169. $server = new Zend_Json_Server();
  170. $server->setClass('Calculator');
  171. if ('GET' == $_SERVER['REQUEST_METHOD']) {
  172. $server->setTarget('/json-rpc.php')
  173. ->setEnvelope(Zend_Json_Server_Smd::ENV_JSONRPC_2);
  174. $smd = $server->getServiceMap();
  175. // Die Kompatibilität zu Dojo setzen:
  176. $smd->setDojoCompatible(true);
  177. header('Content-Type: application/json');
  178. echo $smd;
  179. return;
  180. }
  181. $server->handle();
  182. ]]></programlisting>
  183. </example>
  184. <sect2 id="zend.json.server.details">
  185. <title>Fortgescrittene Details</title>
  186. <para>
  187. Obwohl das meiste an Funktionalität für <classname>Zend_Json_Server</classname> in
  188. <xref linkend="zend.json.server.usage" /> beschrieben wurde, ist noch weitere
  189. fortgeschrittenere Funktionalität vorhanden.
  190. </para>
  191. <sect3 id="zend.json.server.details.zendjsonserver">
  192. <title>Zend_Json_Server</title>
  193. <para>
  194. <classname>Zend_Json_Server</classname> ist die Kernklasse von JSON-RPC; die
  195. bearbeitet alle Anfragen und gibt den Antwort Payload zurück. Sie hat die folgenden
  196. Methoden:
  197. </para>
  198. <itemizedlist>
  199. <listitem>
  200. <para>
  201. <code>addFunction($function)</code>: Spezifiziert eine benutzerdefinierte
  202. Funktion die dem Server hinzugefügt werden soll.
  203. </para>
  204. </listitem>
  205. <listitem>
  206. <para>
  207. <code>setClass($class)</code>: Spezifiziert eine Klasse oder ein Objekt das
  208. dem Server hinzugefügt werden soll; alle öffentlichen Methoden dieses
  209. Elemente werden als JSON-RPC Methoden bekanntgegeben.
  210. </para>
  211. </listitem>
  212. <listitem>
  213. <para>
  214. <code>fault($fault = null, $code = 404, $data = null)</code>: Erstellt und
  215. retourniert ein <classname>Zend_Json_Server_Error</classname> Objekt.
  216. </para>
  217. </listitem>
  218. <listitem>
  219. <para>
  220. <code>handle($request = false)</code>: Behandelt eine JSON-RPC Anfrage;
  221. optional kann ein <classname>Zend_Json_Server_Request</classname> Objekt für
  222. die Anpassung übergeben werden (standardmäßig wird eines erstellt).
  223. </para>
  224. </listitem>
  225. <listitem>
  226. <para>
  227. <code>getFunctions()</code>: Gibt eine Liste aller hinzugefügten Methoden
  228. zurück.
  229. </para>
  230. </listitem>
  231. <listitem>
  232. <para>
  233. <code>setRequest(Zend_Json_Server_Request $request)</code>: Spezifiziert ein
  234. Anfrageobjekt um es für den Server zu verwenden.
  235. </para>
  236. </listitem>
  237. <listitem>
  238. <para>
  239. <code>getRequest()</code>: Empfängt das Anfrageobjekt das vom Server
  240. verwendet wird.
  241. </para>
  242. </listitem>
  243. <listitem>
  244. <para>
  245. <code>setResponse(Zend_Json_Server_Response $response)</code>: Setzt das
  246. Antwort Objekt das der Server verwendet.
  247. </para>
  248. </listitem>
  249. <listitem>
  250. <para>
  251. <code>getResponse()</code>: Empfängt das Anfrageobjekt das vom Server
  252. verwendet wird.
  253. </para>
  254. </listitem>
  255. <listitem>
  256. <para>
  257. <code>setAutoEmitResponse($flag)</code>: Zeigt ob der Server die Antworten
  258. und alle Header automatisch ausgeben sollte; standardmäßig ist das
  259. aktiviert.
  260. </para>
  261. </listitem>
  262. <listitem>
  263. <para>
  264. <code>autoEmitResponse()</code>: Stellt fest ob das automatische senden der
  265. Antwort eingeschaltet ist.
  266. </para>
  267. </listitem>
  268. <listitem>
  269. <para>
  270. <code>getServiceMap()</code>: Empfängt die Service Map Description in der
  271. Form eines <classname>Zend_Json_Server_Smd</classname> Objekts
  272. </para>
  273. </listitem>
  274. </itemizedlist>
  275. </sect3>
  276. <sect3 id="zend.json.server.details.zendjsonserverrequest">
  277. <title>Zend_Json_Server_Request</title>
  278. <para>
  279. Die JSON-RPC Anfrageumgebung ist in ein
  280. <classname>Zend_Json_Server_Request</classname> Objekt eingekapselt. Diese Objekt
  281. erlaubt es die notwendigen Teile der JSON-RPC Anfrage zu setzen, inklusive der
  282. Anfrage ID, Parametern, und der JSON-RPC spezifischen Version. Es hat die
  283. Möglichkeit sich selbst über JSON zu laden oder ein Set von Optionen, und kann sich
  284. selbst über die <code>toJson()</code> Methode als JSON darstellen.
  285. </para>
  286. <para>
  287. Das Anfrage Objekt enthält die folgenden Methoden:
  288. </para>
  289. <itemizedlist>
  290. <listitem>
  291. <para>
  292. <code>setOptions(array $options)</code>: Spezifiziert die Konfiguration des
  293. Objektes. <code>$options</code> kann Schlüssel enthalten die jeglicher 'set'
  294. Methode entsprechen: <code>setParams()</code>, <code>setMethod()</code>,
  295. <code>setId()</code> und <code>setVersion()</code>.
  296. </para>
  297. </listitem>
  298. <listitem>
  299. <para>
  300. <code>addParam($value, $key = null)</code>: Fügt einen Parameter hinzu der
  301. mit einem Methodenaufruf verwendet wird. Parameter können nur Werte sein,
  302. oder optional auch den Parameternamen enthalten.
  303. </para>
  304. </listitem>
  305. <listitem>
  306. <para>
  307. <code>addParams(array $params)</code>: Mehrere Parameter auf einmal
  308. hinzufügen; Ruft <code>addParam()</code> auf
  309. </para>
  310. </listitem>
  311. <listitem>
  312. <para>
  313. <code>setParams(array $params)</code>: Setzt alle Parameter auf einmal;
  314. überschreibt jeden existierenden Parameter.
  315. </para>
  316. </listitem>
  317. <listitem>
  318. <para>
  319. <code>getParam($index)</code>: Empfängt einen Parameter durch seine Position
  320. oder seinen Namen.
  321. </para>
  322. </listitem>
  323. <listitem>
  324. <para><code>getParams()</code>: Empfängt alle Parameter auf einmal.</para>
  325. </listitem>
  326. <listitem>
  327. <para>
  328. <code>setMethod($name)</code>: Setzt die Methode die aufgerufen wird.
  329. </para>
  330. </listitem>
  331. <listitem>
  332. <para><code>getMethod()</code>: Empfängt die Methode die aufgerufen wird.</para>
  333. </listitem>
  334. <listitem>
  335. <para>
  336. <code>isMethodError()</code>: Erkennt ob eine Anfrage fehlerhaft ist und
  337. einen Fehler produzieren würde, oder nicht.
  338. </para>
  339. </listitem>
  340. <listitem>
  341. <para>
  342. <code>setId($name)</code>: Setzt den Identifikator der Anfrage (durch den
  343. Client verwendet um Anfragen auf Antworten abzubilden).
  344. </para>
  345. </listitem>
  346. <listitem>
  347. <para><code>getId()</code>: Empfängt den Anfrage Identifikator.</para>
  348. </listitem>
  349. <listitem>
  350. <para>
  351. <code>setVersion($version)</code>: Setzt die Version der JSON-RPC
  352. Spezifikation der die Anfrage entspricht. Kann entweder '1.0' oder '2.0'
  353. sein.
  354. </para>
  355. </listitem>
  356. <listitem>
  357. <para>
  358. <code>getVersion()</code>: Empfängt die Version der JSON-RPC Spezifikation
  359. die von der Anfrage verwendet wird.
  360. </para>
  361. </listitem>
  362. <listitem>
  363. <para>
  364. <code>loadJson($json)</code>: Läde das Anfrageobjekt von einem JSON String.
  365. </para>
  366. </listitem>
  367. <listitem>
  368. <para><code>toJson()</code>: Stellt den JSON String als Anfrage dar.</para>
  369. </listitem>
  370. </itemizedlist>
  371. <para>
  372. Eine HTTP spezifische Version ist über
  373. <classname>Zend_Json_Server_Request_Http</classname> vorhanden. Diese Klasse
  374. empfängt eine Anfrage über <code>php://input</code> und erlaubt den Zugriff auf die
  375. rohen JSON Daten über die <code>getRawJson()</code> Methode.
  376. </para>
  377. </sect3>
  378. <sect3 id="zend.json.server.details.zendjsonserverresponse">
  379. <title>Zend_Json_Server_Response</title>
  380. <para>
  381. Der JSON-RPC Antwort Payload ist in ein
  382. <classname>Zend_Json_Server_Response</classname> Objekt gekapselt. Diese Objekt
  383. erlaubt es den Rückgabewert der Anfrage zu setzen, ob die Antwort ein Fehler ist
  384. oder nicht, den Anfrageindentifikator, die Version der JSON-RPC Spezifikation der
  385. die Antwort entspricht, und optional die Servicemap.
  386. </para>
  387. <para>
  388. Das Antwortobjekt bietet die folgenden Methoden:
  389. </para>
  390. <itemizedlist>
  391. <listitem>
  392. <para>
  393. <code>setResult($value)</code>: Setzt das Ergebnis der Antwort.
  394. </para>
  395. </listitem>
  396. <listitem>
  397. <para>
  398. <code>getResult()</code>: Empfängt das Antwortergebnis.
  399. </para>
  400. </listitem>
  401. <listitem>
  402. <para>
  403. <code>setError(Zend_Json_Server_Error $error)</code>: Setzt ein
  404. Fehlerobjekt. Wenn es gesetzt wird, wird es als Antwort verwendet wenn JSON
  405. serialisiert wird.
  406. </para>
  407. </listitem>
  408. <listitem>
  409. <para>
  410. <code>getError()</code>: Empfängt das Fehlerobjekt, wenn vorhanden.
  411. </para>
  412. </listitem>
  413. <listitem>
  414. <para>
  415. <code>isError()</code>: Ob die Antwort eine Fehlerantwort ist oder nicht.
  416. </para>
  417. </listitem>
  418. <listitem>
  419. <para>
  420. <code>setId($name)</code>: Setzt den Antwortindentifikator (damit der Client
  421. die Antwort mit der Originalanfrage in Verbindung bringt).
  422. </para>
  423. </listitem>
  424. <listitem>
  425. <para>
  426. <code>getId()</code>: Empfängt den Antwortidentifikator.
  427. </para>
  428. </listitem>
  429. <listitem>
  430. <para>
  431. <code>setVersion($version)</code>: Setzt die JSON-RPC Version der die
  432. Antwort entspricht.
  433. </para>
  434. </listitem>
  435. <listitem>
  436. <para>
  437. <code>getVersion()</code>: Empfängt die JSON-RPC Version der die Antwort
  438. entspricht.
  439. </para>
  440. </listitem>
  441. <listitem>
  442. <para>
  443. <code>toJson()</code>: Serialisiert die Antwort auf JSON. Wenn die Antwort
  444. eine Fehlerantwort ist, wird das Fehlerobjekt serialisiert.
  445. </para>
  446. </listitem>
  447. <listitem>
  448. <para>
  449. <code>setServiceMap($serviceMap)</code>: Setzt das Servicemap Objekt für
  450. die Antwort.
  451. </para>
  452. </listitem>
  453. <listitem>
  454. <para>
  455. <code>getServiceMap()</code>: Empfängt das Servicemap Objekt, wenn es
  456. vorhanden ist.
  457. </para>
  458. </listitem>
  459. </itemizedlist>
  460. <para>
  461. Eine HTTP spezifische Version ist über
  462. <classname>Zend_Json_Server_Response_Http</classname> vorhanden. Diese Klasse wird
  463. entsprechende HTTP Header senden als auch die Antwort auf JSON zu serialisieren.
  464. </para>
  465. </sect3>
  466. <sect3 id="zend.json.server.details.zendjsonservererror">
  467. <title>Zend_Json_Server_Error</title>
  468. <para>
  469. JSON-RPC hat ein spezielles Format für das melden von Fehlerzuständen. Alle Fehler
  470. müssen mindestens, eine Fehlermeldung und einen Fehlercode anbieten; optional können
  471. Sie zusätzliche Daten, wie ein Backtrace, anbieten.
  472. </para>
  473. <para>
  474. Fehlercodes sind von jenen abgeleitet die vom
  475. <ulink url="http://xmlrpc-epi.sourceforge.net/specs/rfc.fault_codes.php">vom XML-RPC
  476. EPI Projekt</ulink> empfohlen werden. <classname>Zend_Json_Server</classname>
  477. fügt den richtigen Code basierend auf der Fehlerkondition zu. Für
  478. Anwendungsausnahmen wird der Code '-32000' verwendet.
  479. </para>
  480. <para>
  481. <classname>Zend_Json_Server_Error</classname> bietet die folgenden Methoden:
  482. </para>
  483. <itemizedlist>
  484. <listitem>
  485. <para>
  486. <code>setCode($code)</code>: Setzt den Fehlercode: Wenn der Code nicht im
  487. akzeptierten Bereich der XML-RPC Fehlercodes ist, wird -32000 hinzugefügt.
  488. </para>
  489. </listitem>
  490. <listitem>
  491. <para>
  492. <code>getCode()</code>: Empfängt den aktuellen Fehlercode.
  493. </para>
  494. </listitem>
  495. <listitem>
  496. <para>
  497. <code>setMessage($message)</code>: Setzt die Fehlernachricht.
  498. </para>
  499. </listitem>
  500. <listitem>
  501. <para>
  502. <code>getMessage()</code>: Empfängt die aktuelle Fehlernachricht.
  503. </para>
  504. </listitem>
  505. <listitem>
  506. <para>
  507. <code>setData($data)</code>: Setzt zusätzliche Daten die den Fehler
  508. genauer qualifizieren, wie ein Backtrace.
  509. </para>
  510. </listitem>
  511. <listitem>
  512. <para>
  513. <code>getData()</code>: Empfängt alle aktuellen zusätzlichen Fehlerdaten.
  514. </para>
  515. </listitem>
  516. <listitem>
  517. <para>
  518. <code>toArray()</code>: Weist den Fehler einem Array zu. Das Array enthält
  519. die Schlüssel 'code', 'message' und 'data'.
  520. </para>
  521. </listitem>
  522. <listitem>
  523. <para>
  524. <code>toJson()</code>: Weist den Fehler einer JSON-RPC Fehlerrepräsentation
  525. zu.
  526. </para>
  527. </listitem>
  528. </itemizedlist>
  529. </sect3>
  530. <sect3 id="zend.json.server.details.zendjsonserversmd">
  531. <title>Zend_Json_Server_Smd</title>
  532. <para>
  533. SMD steht für Service Mapping Description, ein JSON Schema das definiert wie ein
  534. Client mit einem speziellen Web Service interagieren kann. Zu der Zeit wie das
  535. geschrieben wurde, wurde die <ulink
  536. url="http://groups.google.com/group/json-schema/web/service-mapping-description-proposal">Spezifikation</ulink>
  537. noch nicht formell ratifiziert, aber Sie ist bereits im Dojo Toolkit in Verwendung
  538. sowie in anderen JSON-RPC Kundenclients.
  539. </para>
  540. <para>
  541. Grundsätzlich bezeichnet eine Service Mapping Description die Methode des Transports
  542. (POST, GET, TCP/IP, usw.), den Envelopetyp der Anfrage (normalerweise basierend auf
  543. dem Protokoll des Servers), die ZielURL des Service Providers, und eine Mappe der
  544. vorhandenen Services. Im FAll von JSON-RPC ist die Service Mappe eine Liste von
  545. vorhandenen Methoden wobei jede Methode die vorhandenen Parameter und deren Typen
  546. beschreibt, sowie den erwarteten Typ des Rückgabewerts.
  547. </para>
  548. <para>
  549. <classname>Zend_Json_Server_Smd</classname> bietet einen Objektorientierten Weg um
  550. Service Mappen zu erstellen. Grundsätzlich werden Ihm Metadaten übergeben die den
  551. Service beschreiben indem Mutatoren verwendet und Services (Methoden und Funktionen)
  552. spezifiziert werden.
  553. </para>
  554. <para>
  555. Die Servicebeschreibungen selbst sind typischerweise Instanzen von
  556. <classname>Zend_Json_Server_Smd_Service</classname>; man kann genauso alle
  557. Informationen als Array an die verschiedenen Servicemutatoren in
  558. <classname>Zend_Json_Server_Smd</classname> übergeben, und es wird für einen ein
  559. Serviceobjekt instanziieren. Die Serviceobjekte enthalten Informationen wie den
  560. Namen des Services (typischerweise die Funktion oder den Methodennamen), die
  561. Parameter (Namen, Typen und Position), und den Typ des Rückgabewerts. Optionen kann
  562. jedes Service sein eigenes Ziel und Envelope haben, obwohl diese Funktionalität
  563. selten verwendet wird.
  564. </para>
  565. <para>
  566. <classname>Zend_Json_Server</classname> führt all das im Hintergrund durch, indem
  567. Reflektion auf den hinzugefügten Klassen und Funktionen verwendet wird; man sollte
  568. seine eigenen Service Maps erstellen wenn man eigene Funktionalitäten anbieten will
  569. die die Introspektion von Klassen und Funktionen nicht bieten kann.
  570. </para>
  571. <para>
  572. Die vorhandenen Methoden in <classname>Zend_Json_Server_Smd</classname> enthalten:
  573. </para>
  574. <itemizedlist>
  575. <listitem>
  576. <para>
  577. <code>setOptions(array $options)</code>: Erstelle ein SMD Objekt von einem
  578. Array an Optionen. Alle Mutatoren (Methoden die mit 'set' beginnen) können
  579. als Schlüssel verwendet werden.
  580. </para>
  581. </listitem>
  582. <listitem>
  583. <para>
  584. <code>setTransport($transport)</code>: Setzt den Transport der für den
  585. Zugriff auf das Service verwendet werden soll; aktuell wird nur POST
  586. unterstützt.
  587. </para>
  588. </listitem>
  589. <listitem>
  590. <para>
  591. <code>getTransport()</code>: Empfängt den aktuellen Transport des Services.
  592. </para>
  593. </listitem>
  594. <listitem>
  595. <para>
  596. <code>setEnvelope($envelopeType)</code>: Setzt den aktuelle Anfrageenvelope
  597. der verwendet werden sollte um auf den Service zuzugreifen. Aktuell werden
  598. die Konstanten <classname>Zend_Json_Server_Smd::ENV_JSONRPC_1</classname>
  599. und <classname>Zend_Json_Server_Smd::ENV_JSONRPC_2</classname> verwendet.
  600. </para>
  601. </listitem>
  602. <listitem>
  603. <para>
  604. <code>getEnvelope()</code>: Empfängt den aktuellen Anfrageenvelope.
  605. </para>
  606. </listitem>
  607. <listitem>
  608. <para>
  609. <code>setContentType($type)</code>: Setzt den Contenttype den Anfragen
  610. verwenden sollten (standardmäßig ist das 'application/json').
  611. </para>
  612. </listitem>
  613. <listitem>
  614. <para>
  615. <code>getContentType()</code>: Empfängt den aktuellen Contenttype für
  616. Anfragen an den Service.
  617. </para>
  618. </listitem>
  619. <listitem>
  620. <para>
  621. <code>setTarget($target)</code>: Setzt den aktuellen URL Endpunkt für den
  622. Service.
  623. </para>
  624. </listitem>
  625. <listitem>
  626. <para>
  627. <code>getTarget()</code>: Empfängt den URL Endpunkt für den Service.
  628. </para>
  629. </listitem>
  630. <listitem>
  631. <para>
  632. <code>setId($id)</code>: Tpischerweise ist das der URL Endpunkt des
  633. Services (der selbe wie das Ziel).
  634. </para>
  635. </listitem>
  636. <listitem>
  637. <para>
  638. <code>getId()</code>: Empfängt die ServiceID (typischerweise der URL
  639. Endpunkt des Services).
  640. </para>
  641. </listitem>
  642. <listitem>
  643. <para>
  644. <code>setDescription($description)</code>: Setzt eine Servicebeschreibung
  645. (typischerweise nähere Informationen die den Zweck des Services
  646. beschreiben).
  647. </para>
  648. </listitem>
  649. <listitem>
  650. <para>
  651. <code>getDescription()</code>: Empfängt die Servicebeschreibung.
  652. </para>
  653. </listitem>
  654. <listitem>
  655. <para>
  656. <code>setDojoCompatible($flag)</code>: Setzt ein Flag das indiziert ob das
  657. SMD mit dem Dojo Toolkit kompatibel ist oder nicht. Wenn es true ist, dann
  658. ist das erzeugte JSON SMD so formatiert das es dem Format entspricht das
  659. Dojo's JSON-RPC Client erwartet.
  660. </para>
  661. </listitem>
  662. <listitem>
  663. <para>
  664. <code>isDojoCompatible()</code>: Gibt den Wert des Dojokompatibilitätsflags
  665. zurück (Standardmäßig false).
  666. </para>
  667. </listitem>
  668. <listitem>
  669. <para>
  670. <code>addService($service)</code>: Fügt ein Service der Mappe hinzu. Kann
  671. ein Array von Informationen sein die an den Konstruktor von
  672. <classname>Zend_Json_Server_Smd_Service</classname> übergeben werden, oder
  673. eine Instanz dieser Klasse.
  674. </para>
  675. </listitem>
  676. <listitem>
  677. <para>
  678. <code>addServices(array $services)</code>: Fügt mehrere Services auf einmal
  679. hinzu.
  680. </para>
  681. </listitem>
  682. <listitem>
  683. <para>
  684. <code>setServices(array $services)</code>: Fügt mehrere Serices auf einmal
  685. hinzu, und überschreibt alle vorher gesetzten Services.
  686. </para>
  687. </listitem>
  688. <listitem>
  689. <para>
  690. <code>getService($name)</code>: Gibt ein Service durch seinen Namen zurück.
  691. </para>
  692. </listitem>
  693. <listitem>
  694. <para>
  695. <code>getServices()</code>: Gibt alle hinzugefügten Services zurück.
  696. </para>
  697. </listitem>
  698. <listitem>
  699. <para>
  700. <code>removeService($name)</code>: Entfernt ein Service von der Mappe.
  701. </para>
  702. </listitem>
  703. <listitem>
  704. <para>
  705. <code>toArray()</code>: Weißt die Service Mappe einem Array zu.
  706. </para>
  707. </listitem>
  708. <listitem>
  709. <para>
  710. <code>toDojoArray()</code>: Weißt die Service Mappe einem Array zu das
  711. mit dem Dojo Toolkit kompatibel ist.
  712. </para>
  713. </listitem>
  714. <listitem>
  715. <para>
  716. <code>toJson()</code>: Weißt die Service Mappe einer JSON
  717. Repräsentation zu.
  718. </para>
  719. </listitem>
  720. </itemizedlist>
  721. <para>
  722. <classname>Zend_Json_Server_Smd_Service</classname> hat die folgenden Methoden:
  723. </para>
  724. <itemizedlist>
  725. <listitem>
  726. <para>
  727. <code>setOptions(array $options)</code>: Setzt den Objektstatus durch ein
  728. Array. Jeder Mutator (Methoden die mit 'set' beginnen, kann als Schlüssel
  729. verwendet und über diese Methode gesetzt werden.
  730. </para>
  731. </listitem>
  732. <listitem>
  733. <para>
  734. <code>setName($name)</code>: Setzt den Namen des Services (typischerweise
  735. die Funktion oder den Methodennamen).
  736. </para>
  737. </listitem>
  738. <listitem>
  739. <para>
  740. <code>getName()</code>: Empfängt den Servicenamen.
  741. </para>
  742. </listitem>
  743. <listitem>
  744. <para>
  745. <code>setTransport($transport)</code>: Setzt den Transport des Services
  746. (aktuell werden nur Transporte unterstützt die in
  747. <classname>Zend_Json_Server_Smd</classname> erlaubt sind).
  748. </para>
  749. </listitem>
  750. <listitem>
  751. <para>
  752. <code>getTransport()</code>: Empfängt den aktuellen Transport.
  753. </para>
  754. </listitem>
  755. <listitem>
  756. <para>
  757. <code>setTarget($target)</code>: Setzt den URL-Endpunkt des Services
  758. (typischerweise ist das der selbe wir im gesamten SMD welchem der Service
  759. hinzugefügt wird).
  760. </para>
  761. </listitem>
  762. <listitem>
  763. <para>
  764. <code>getTarget()</code>: Gibt den URL Endpunkt des Services zurück.
  765. </para>
  766. </listitem>
  767. <listitem>
  768. <para>
  769. <code>setEnvelope($envelopeType)</code>: Setzt den Serviceenvelope
  770. (aktuell werden nur Envelopes unterstützt die in
  771. <classname>Zend_Json_Server_Smd</classname> erlaubt sind).
  772. </para>
  773. </listitem>
  774. <listitem>
  775. <para>
  776. <code>getEnvelope()</code>: Empfängt den Typ des Serviceenvelopes.
  777. </para>
  778. </listitem>
  779. <listitem>
  780. <para>
  781. <code>addParam($type, array $options = array(), $order = null)</code>:
  782. Fügt dem Service einen Parameter hinzu. Standardmäßig ist nur der
  783. Parametertyp notwendig. Trotzdem kann die Reihenfolge spezifiziert werden
  784. sowie auch Optionen wie:</para>
  785. <itemizedlist>
  786. <listitem>
  787. <para>
  788. <emphasis>name</emphasis>: Der Name des Parameters
  789. </para>
  790. </listitem>
  791. <listitem>
  792. <para>
  793. <emphasis>optional</emphasis>: Ob der Parameter optional ist oder
  794. nicht
  795. </para>
  796. </listitem>
  797. <listitem>
  798. <para>
  799. <emphasis>default</emphasis>: Ein Standardwert für diesen Parameter
  800. </para>
  801. </listitem>
  802. <listitem>
  803. <para>
  804. <emphasis>description</emphasis>: Ein Text der den Parameter
  805. beschreibt
  806. </para>
  807. </listitem>
  808. </itemizedlist>
  809. </listitem>
  810. <listitem>
  811. <para>
  812. <code>addParams(array $params)</code>: Fügt verschiedene Parameter auf
  813. einmal hinzu; jeder Parameter sollte ein Assoziatives Array sein das
  814. mindestens den Schlüssel 'type' enthält welches den Typ des Parameters
  815. beschreibt, und optinal den Schlüssel 'order'; jeden andere Schlüssel wird
  816. als <code>$options</code> an <code>addOption()</code> übergeben.
  817. </para>
  818. </listitem>
  819. <listitem>
  820. <para>
  821. <code>setParams(array $params)</code>: Setzt viele Parameter aus einmal,
  822. überschreibt alle aktuellen Parameter auf einmal.
  823. </para>
  824. </listitem>
  825. <listitem>
  826. <para>
  827. <code>getParams()</code>: Empfängt alle aktuell gesetzten Parameter.
  828. </para>
  829. </listitem>
  830. <listitem>
  831. <para>
  832. <code>setReturn($type)</code>: Setzt den Type des Rückgabewertes des
  833. Services.
  834. </para>
  835. </listitem>
  836. <listitem>
  837. <para>
  838. <code>getReturn()</code>: Empfängt den Typ des Rückgabewertes des Services.
  839. </para>
  840. </listitem>
  841. <listitem>
  842. <para>
  843. <code>toArray()</code>: Weist das Service an ein Array zu.
  844. </para>
  845. </listitem>
  846. <listitem>
  847. <para>
  848. <code>toJson()</code>: Weist das Service einer JSON Repräsentation zu.
  849. </para>
  850. </listitem>
  851. </itemizedlist>
  852. </sect3>
  853. </sect2>
  854. </sect1>
  855. <!--
  856. vim:se ts=4 sw=4 et:
  857. -->