Zend_Json-Server.xml 41 KB

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