Zend_Json-Server.xml 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 19477 -->
  4. <sect1 id="zend.json.server">
  5. <title>Zend_Json_Server - JSON-RPCサーバー</title>
  6. <para>
  7. <classname>Zend_Json_Server</classname>は<ulink
  8. url="http://groups.google.com/group/json-rpc/">JSON-RPC</ulink>
  9. サーバー実装です。それは
  10. <ulink url="http://groups.google.com/group/json-rpc/web/json-rpc-1-2-proposal">バージョン 2 仕様</ulink>
  11. と同様に
  12. <ulink url="http://json-rpc.org/wiki/specification">JSON-RPCバージョン 1 仕様</ulink>
  13. の両方をサポートします;
  14. それは、サービスのメタデータをサービス利用者に提供するために、
  15. <ulink url="http://groups.google.com/group/json-schema/web/service-mapping-description-proposal">サービス
  16. マッピング定義 (SMD) 仕様</ulink>の
  17. <acronym>PHP</acronym>実装を提供します。
  18. </para>
  19. <para>
  20. JSON-RPCは、軽量なリモート・プロシージャ呼出しプロトコルです。
  21. そのプロトコルでは、<acronym>JSON</acronym>をそのメッセージのエンベロープのために利用します。
  22. このJSON-RPC実装は<acronym>PHP</acronym>の<ulink
  23. url="http://www.php.net/manual/ja/class.soapserver.php">SoapServer</ulink>
  24. <acronym>API</acronym>に従います。
  25. このことにより典型的状況では、簡単に下記のことができます:
  26. </para>
  27. <itemizedlist>
  28. <listitem><para>サーバーオブジェクトのインスタンス化</para></listitem>
  29. <listitem><para>一つ以上の関数やクラス/オブジェクトをサーバーオブジェクトに配置</para></listitem>
  30. <listitem><para>リクエストの handle()</para></listitem>
  31. </itemizedlist>
  32. <para>
  33. <classname>Zend_Json_Server</classname>は
  34. どんな付属のクラスまたは関数でも<xref linkend="zend.server.reflection" />Reflectionを実行することを利用します。
  35. また、SMDと実施するメソッド呼び出しのシグナチュアとの両方をビルドするためにその情報を使います。
  36. そのように、それはどんな付属の関数またはクラス・メソッドでも完全な<acronym>PHP</acronym> docblock文書を最小限、持つ命令文です:
  37. </para>
  38. <itemizedlist>
  39. <listitem><para>パラメータとそれらで期待される変数の型の全て</para></listitem>
  40. <listitem><para>戻り値変数の型</para></listitem>
  41. </itemizedlist>
  42. <para>
  43. <classname>Zend_Json_Server</classname>はこの時だけPOSTリクエストをリスンします;
  44. 幸いにも、この文書の時点では、ワイルドなJSON-RPC実装の大半は、
  45. そのようにリクエストをポストするだけです。
  46. 次の例で示されるように、
  47. リクエストの処理だけではなく、サービスSMDの配信の両方で
  48. 同じサーバーエンドポイントを簡単に利用できるようにします。
  49. </para>
  50. <example id="zend.json.server.usage">
  51. <title>Zend_Json_Server利用方法</title>
  52. <para>
  53. 最初に、JSON-RPCサーバーによって公開したいクラスを定義しましょう。
  54. そのクラスを 'Calculator' とし、
  55. 'add'、'subtract'、'multiply' 及び 'divide'メソッドを定義します:
  56. </para>
  57. <programlisting language="php"><![CDATA[
  58. /**
  59. * Calculator - JSON-RPCを通じて公開するサンプル・クラス。
  60. */
  61. class Calculator
  62. {
  63. /**
  64. * 2つの変数の合計を返します
  65. *
  66. * @param int $x
  67. * @param int $y
  68. * @return int
  69. */
  70. public function add($x, $y)
  71. {
  72. return $x + $y;
  73. }
  74. /**
  75. * 2つの変数の差を返します
  76. *
  77. * @param int $x
  78. * @param int $y
  79. * @return int
  80. */
  81. public function subtract($x, $y)
  82. {
  83. return $x - $y;
  84. }
  85. /**
  86. * 2つの変数の積を返します
  87. *
  88. * @param int $x
  89. * @param int $y
  90. * @return int
  91. */
  92. public function multiply($x, $y)
  93. {
  94. return $x * $y;
  95. }
  96. /**
  97. * 2つの変数の除算結果を返します
  98. *
  99. * @param int $x
  100. * @param int $y
  101. * @return float
  102. */
  103. public function divide($x, $y)
  104. {
  105. return $x / $y;
  106. }
  107. }
  108. ]]></programlisting>
  109. <para>
  110. それぞれのメソッドで戻り値のための項目だけでなく、
  111. それぞれのパラメータとその型を示す項目を持つdocblockを持つことに注意してください。
  112. それに関しては、Zend Frameworkで<classname>Zend_Json_Server</classname>や
  113. その他のいずれのサーバー構成要素を利用するときでも、これは<emphasis>絶対重要</emphasis>です。
  114. </para>
  115. <para>
  116. それでは、リクエストを処理するためのスクリプトを作成します:
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. $server = new Zend_Json_Server();
  120. // どのような機能が利用できるか示します:
  121. $server->setClass('Calculator');
  122. //リクエストを処理:
  123. $server->handle();
  124. ]]></programlisting>
  125. <para>
  126. しかしながら、JSON-RPCクライアントがメソッドを自動検出できるように、
  127. SMDを返す問題を対象にしません。
  128. それは、<acronym>HTTP</acronym>がメソッドをリクエストすることを確定し、
  129. それから、若干のサーバー・メタデータを指定することによって達成されます:
  130. </para>
  131. <programlisting language="php"><![CDATA[
  132. $server = new Zend_Json_Server();
  133. $server->setClass('Calculator');
  134. if ('GET' == $_SERVER['REQUEST_METHOD']) {
  135. // URLのエンドポイント及び使用するJSON-RPCのバージョンを示します:
  136. $server->setTarget('/json-rpc.php')
  137. ->setEnvelope(Zend_Json_Server_Smd::ENV_JSONRPC_2);
  138. // SMDをつかみます
  139. $smd = $server->getServiceMap();
  140. // クライアントにSMDを返します
  141. header('Content-Type: application/json');
  142. echo $smd;
  143. return;
  144. }
  145. $server->handle();
  146. ]]></programlisting>
  147. <para>
  148. DojoツールキットでJSON-RPCサーバーを利用するなら、
  149. その2つがきちんと相互作用することを確実にするために、
  150. 特別な互換性フラグをセットする必要もあります:
  151. </para>
  152. <programlisting language="php"><![CDATA[
  153. $server = new Zend_Json_Server();
  154. $server->setClass('Calculator');
  155. if ('GET' == $_SERVER['REQUEST_METHOD']) {
  156. $server->setTarget('/json-rpc.php')
  157. ->setEnvelope(Zend_Json_Server_Smd::ENV_JSONRPC_2);
  158. $smd = $server->getServiceMap();
  159. // Dojo互換を設定します:
  160. $smd->setDojoCompatible(true);
  161. header('Content-Type: application/json');
  162. echo $smd;
  163. return;
  164. }
  165. $server->handle();
  166. ]]></programlisting>
  167. </example>
  168. <sect2 id="zend.json.server.details">
  169. <title>高度な詳細</title>
  170. <para>
  171. <classname>Zend_Json_Server</classname>の機能の大半が
  172. <xref linkend="zend.json.server.usage" />で説明されており、
  173. より高度な機能を利用できます。
  174. </para>
  175. <sect3 id="zend.json.server.details.zendjsonserver">
  176. <title>Zend_Json_Server</title>
  177. <para>
  178. <classname>Zend_Json_Server</classname>は、
  179. JSON-RPCを提供する中心的なクラスです;
  180. それはすべてのリクエストを扱い、
  181. レスポンス・ペイロードを返します。
  182. 下記のメソッドがあります:
  183. </para>
  184. <itemizedlist>
  185. <listitem><para><methodname>addFunction($function)</methodname>:
  186. サーバーに関連するユーザーランド関数を指定します。
  187. </para></listitem>
  188. <listitem><para><methodname>setClass($class)</methodname>:
  189. サーバーに関連するクラスまたはオブジェクトを指定します;
  190. そのアイテムのすべてのpublicメソッドは、
  191. JSON-RPCメソッドに公開されます。
  192. </para></listitem>
  193. <listitem><para><code>fault($fault = null, $code = 404, $data =
  194. null)</code>:
  195. <classname>Zend_Json_Server_Error</classname>オブジェクトを生成して返します。
  196. </para></listitem>
  197. <listitem><para><methodname>handle($request = false)</methodname>:
  198. JSON-RPCリクエストを処理します;
  199. 任意で、利用するための<classname>Zend_Json_Server_Request</classname>オブジェクトを渡します。
  200. (デフォルトで1つ生成されます)
  201. </para></listitem>
  202. <listitem><para><methodname>getFunctions()</methodname>:
  203. 付属のメソッド全ての一覧を返します。
  204. </para></listitem>
  205. <listitem><para><code>setRequest(Zend_Json_Server_Request
  206. $request)</code>:
  207. サーバーのために使用するためのリクエストオブジェクトを指定します。
  208. </para></listitem>
  209. <listitem><para><methodname>getRequest()</methodname>:
  210. サーバーで使われるリクエストオブジェクトを取得します。
  211. </para></listitem>
  212. <listitem><para><code>setResponse(Zend_Json_Server_Response
  213. $response)</code>:
  214. サーバーのために使用するためのレスポンスオブジェクトを設定します。
  215. </para></listitem>
  216. <listitem><para><methodname>getResponse()</methodname>:
  217. サーバーで使われるレスポンスオブジェクトを取得します。
  218. </para></listitem>
  219. <listitem><para><methodname>setAutoEmitResponse($flag)</methodname>:
  220. サーバーがレスポンスとすべてのヘッダを自動的に送り出さなければならないかどうか示します;
  221. デフォルトで、これはtrueです。
  222. </para></listitem>
  223. <listitem><para><methodname>autoEmitResponse()</methodname>:
  224. レスポンスの自動送出が使用可能かどうか決定します。
  225. </para></listitem>
  226. <listitem><para><methodname>getServiceMap()</methodname>:
  227. <classname>Zend_Json_Server_Smd</classname>オブジェクトの形で
  228. サービス・マップ記述を取得します
  229. </para></listitem>
  230. </itemizedlist>
  231. </sect3>
  232. <sect3 id="zend.json.server.details.zendjsonserverrequest">
  233. <title>Zend_Json_Server_Request</title>
  234. <para>
  235. JSON-RPCのリクエスト環境は、
  236. <classname>Zend_Json_Server_Request</classname>オブジェクトにカプセル化されます。
  237. このオブジェクトによって、リクエストIDやパラメータ、JSON-RPC仕様のバージョンを含む
  238. JSON-RPCリクエストの必要な部分を設定できます。
  239. それには<acronym>JSON</acronym>または一組のオプションによってそれ自体をロードする能力があって、
  240. それ自体を<methodname>toJson()</methodname>メソッドにより<acronym>JSON</acronym>として翻訳できます。
  241. </para>
  242. <para>
  243. リクエスト・オブジェクトでは、以下のメソッドを利用できます:
  244. </para>
  245. <itemizedlist>
  246. <listitem><para><methodname>setOptions(array $options)</methodname>:
  247. オブジェクトの設定を指定します。
  248. <varname>$options</varname>は、どの 'set' メソッドにもマッチするキーを含むでしょう:
  249. <methodname>setParams()</methodname>、<methodname>setMethod()</methodname>、
  250. <methodname>setId()</methodname>及び<methodname>setVersion()</methodname>
  251. </para></listitem>
  252. <listitem><para><methodname>addParam($value, $key = null)</methodname>:
  253. メソッド呼び出しで使うパラメータを追加します。
  254. パラメータは値そのものか、パラメータ名を任意に含むことができます。
  255. </para></listitem>
  256. <listitem><para><methodname>addParams(array $params)</methodname>:
  257. 一度に複数のパラメータを追加します。
  258. <methodname>addParam()</methodname>の代わりになります。
  259. </para></listitem>
  260. <listitem><para><methodname>setParams(array $params)</methodname>:
  261. 一度に全てのパラメータを設定します;
  262. 既存の全てのパラメータを上書きします。
  263. </para></listitem>
  264. <listitem><para><methodname>getParam($index)</methodname>:
  265. 位置または名前でパラメータを返します。
  266. </para></listitem>
  267. <listitem><para><methodname>getParams()</methodname>:
  268. 一度に全てのパラメータを返します。
  269. </para></listitem>
  270. <listitem><para><methodname>setMethod($name)</methodname>:
  271. 呼び出すメソッドを設定します。
  272. </para></listitem>
  273. <listitem><para><methodname>getMethod()</methodname>:
  274. 呼び出されるメソッドを取得します。
  275. </para></listitem>
  276. <listitem><para><methodname>isMethodError()</methodname>:
  277. リクエストが異常で、エラーに終わるかどうか決定します。
  278. </para></listitem>
  279. <listitem><para><methodname>setId($name)</methodname>:
  280. リクエスト識別子(クライアントでレスポンスにリクエストにマッチすることに使われる)をセットします。
  281. </para></listitem>
  282. <listitem><para><methodname>getId()</methodname>:
  283. リクエストの識別子を取得します。
  284. </para></listitem>
  285. <listitem><para><methodname>setVersion($version)</methodname>:
  286. リクエストが適合するJSON-RPC仕様バージョンを設定します。
  287. おそらく '1.0' かまたは '2.0' のどちらかです。
  288. </para></listitem>
  289. <listitem><para><methodname>getVersion()</methodname>:
  290. リクエストで使われるJSON-RPC仕様バージョンを取得します。
  291. </para></listitem>
  292. <listitem><para><methodname>loadJson($json)</methodname>:
  293. <acronym>JSON</acronym>文字列からリクエストオブジェクトを読み込みます。
  294. </para></listitem>
  295. <listitem><para><methodname>toJson()</methodname>:
  296. リクエストを<acronym>JSON</acronym>ストリングに翻訳します。
  297. </para></listitem>
  298. </itemizedlist>
  299. <para>
  300. <acronym>HTTP</acronym>に特有のバージョンは、
  301. <classname>Zend_Json_Server_Request_Http</classname>を通して利用できます。
  302. このクラスは<code>php://input</code>を通じてリクエストを取得し、
  303. <methodname>getRawJson()</methodname>メソッドを通じて生の<acronym>JSON</acronym>へのアクセスを可能にします。
  304. </para>
  305. </sect3>
  306. <sect3 id="zend.json.server.details.zendjsonserverresponse">
  307. <title>Zend_Json_Server_Response</title>
  308. <para>
  309. JSON-RPCレスポンス・ペイロードは、
  310. <classname>Zend_Json_Server_Response</classname>オブジェクトにカプセル化されます。
  311. このオブジェクトにより、
  312. リクエストの戻り値、レスポンスがエラーかどうか、
  313. リクエスト識別子、レスポンスが従うJSON-RPC仕様バージョン、
  314. そして任意にサービス・マップをセットできます。
  315. </para>
  316. <para>
  317. レスポンス・オブジェクトでは、以下のメソッドを利用できます:
  318. </para>
  319. <itemizedlist>
  320. <listitem><para><methodname>setResult($value)</methodname>:
  321. レスポンス結果を設定します。
  322. </para></listitem>
  323. <listitem><para><methodname>getResult()</methodname>:
  324. レスポンス結果を取得します。
  325. </para></listitem>
  326. <listitem><para><code>setError(Zend_Json_Server_Error
  327. $error)</code>:
  328. エラーオブジェクトを設定します。
  329. 設定すると、<acronym>JSON</acronym>にシリアライズ化するとき、これがレスポンスとして使われます。
  330. </para></listitem>
  331. <listitem><para><methodname>getError()</methodname>:
  332. もしあれば、エラーオブジェクトを取得します。
  333. </para></listitem>
  334. <listitem><para><methodname>isError()</methodname>:
  335. レスポンスがエラー・レスポンスであるかどうか。
  336. </para></listitem>
  337. <listitem><para><methodname>setId($name)</methodname>:
  338. リクエスト識別子
  339. (クライアントはオリジナルのリクエストでレスポンスにマッチするかもしれません)
  340. を設定します。
  341. </para></listitem>
  342. <listitem><para><methodname>getId()</methodname>:
  343. リクエスト識別子を取得します。
  344. </para></listitem>
  345. <listitem><para><methodname>setVersion($version)</methodname>:
  346. レスポンスが適合するJSON-RPCバージョンを設定します。
  347. </para></listitem>
  348. <listitem><para><methodname>getVersion()</methodname>:
  349. レスポンスが適合するJSON-RPCバージョンを取得します。
  350. </para></listitem>
  351. <listitem><para><methodname>toJson()</methodname>:
  352. レスポンスがエラー・レスポンスで、エラー・オブジェクトをシリアライズ化するならば、
  353. <acronym>JSON</acronym>に対するレスポンスをシリアライズ化します。
  354. </para></listitem>
  355. <listitem><para><methodname>setServiceMap($serviceMap)</methodname>:
  356. サービス・マップ・オブジェクトをレスポンスに設定します。
  357. </para></listitem>
  358. <listitem><para><methodname>getServiceMap()</methodname>:
  359. もしあれば、サービス・マップ・オブジェクトを取得します。
  360. </para></listitem>
  361. </itemizedlist>
  362. <para>
  363. <acronym>HTTP</acronym>に依存したバージョンは、
  364. <classname>Zend_Json_Server_Response_Http</classname>を通じて利用できます。
  365. このクラスは<acronym>JSON</acronym>としてレスポンスをシリアライズ化するだけでなく、
  366. 適切な<acronym>HTTP</acronym>ヘッダを送ります。
  367. </para>
  368. </sect3>
  369. <sect3 id="zend.json.server.details.zendjsonservererror">
  370. <title>Zend_Json_Server_Error</title>
  371. <para>
  372. JSON-RPCには、エラー状況を報告するために、特別なフォーマットがあります。
  373. エラーはすべて、最小限、エラー・メッセージとエラーコードを用意する必要があります;
  374. 任意に、追加のデータ(例えばbacktrace)を用意できます。
  375. </para>
  376. <para>
  377. エラーコードは、
  378. <ulink url="http://xmlrpc-epi.sourceforge.net/specs/rfc.fault_codes.php">
  379. XML-RPC EPIプロジェクト</ulink>によって推奨されるコードに由来します。
  380. <classname>Zend_Json_Server</classname>は、エラー状態に基づくコードを適切に割り当てます。
  381. アプリケーション例外のためには、コード '-32000' が使われます。
  382. </para>
  383. <para>
  384. <classname>Zend_Json_Server_Error</classname>
  385. は以下のメソッドを公開します:
  386. </para>
  387. <itemizedlist>
  388. <listitem><para><methodname>setCode($code)</methodname>:
  389. エラーコードを設定します;
  390. 認められたXML-RPCエラーコード範囲にそのコードがないならば、
  391. -32000が割り当てられます。
  392. </para></listitem>
  393. <listitem><para><methodname>getCode()</methodname>:
  394. 現行のエラーコードを取得します。
  395. </para></listitem>
  396. <listitem><para><methodname>setMessage($message)</methodname>:
  397. エラーメッセージを設定します。
  398. </para></listitem>
  399. <listitem><para><methodname>getMessage()</methodname>:
  400. 現行のエラーメッセージを取得します。
  401. </para></listitem>
  402. <listitem><para><methodname>setData($data)</methodname>:
  403. backtraceのような、
  404. エラーを制限する補助データをさらにセットします。
  405. </para></listitem>
  406. <listitem><para><methodname>getData()</methodname>:
  407. 現行のエラー補助データをいずれも取得します。
  408. </para></listitem>
  409. <listitem><para><methodname>toArray()</methodname>:
  410. エラーを配列にキャストします。
  411. 配列は 'code'や'message'及び'data'キーを含むでしょう。
  412. </para></listitem>
  413. <listitem><para><methodname>toJson()</methodname>:
  414. エラーをJSON-RPCエラー表現にキャストします。
  415. </para></listitem>
  416. </itemizedlist>
  417. </sect3>
  418. <sect3 id="zend.json.server.details.zendjsonserversmd">
  419. <title>Zend_Json_Server_Smd</title>
  420. <para>
  421. SMDは、サービス・マッピング記述、
  422. 特定のウェブ・サービスとクライアントが相互作用できる方法を定義する<acronym>JSON</acronym>スキーマ、を表します。
  423. この文書の時点では、
  424. <ulink url="http://groups.google.com/group/json-schema/web/service-mapping-description-proposal">
  425. 仕様</ulink>は正式にまだ批准されませんでした、
  426. しかし、それは他のJSON-RPC利用者のクライアントだけでなく、
  427. Dojoツールキットの範囲内ですでに使用中です。
  428. </para>
  429. <para>
  430. 最も基本的には、サービス・マッピング記述は、トランスポート(POST、GET、<acronym>TCP</acronym>/IP、その他)
  431. リクエスト・エンベロープ・タイプ(通常、サーバーのプロトコルに基づきます)、
  432. サービスプロバイダのターゲット<acronym>URL</acronym>、
  433. そして利用できるサービスマップのメソッドを示します。
  434. JSON-RPCの場合、サービス・マップは利用できるメソッドのリストです、
  435. そしてそれは、各々のメソッドの期待される戻り値タイプだけでなく、
  436. 利用できるパラメータとタイプを文書化します。
  437. </para>
  438. <para>
  439. <classname>Zend_Json_Server_Smd</classname>は、
  440. サービス・マップをビルドするオブジェクト指向方法を準備します。
  441. 最も基本的には、ミューテータを用いてサービスを記述しているメタデータをそれに渡して、
  442. サービス(メソッドと関数)を指定します。
  443. </para>
  444. <para>
  445. サービス記述自体は、
  446. 一般的に<classname>Zend_Json_Server_Smd_Service</classname>のインスタンスです;
  447. <classname>Zend_Json_Server_Smd</classname>の
  448. いろいろなサービス・ミューテータへの配列としてすべての情報を渡すこともできます、
  449. そして、それはサービス・オブジェクトのインスタンスを生成します。
  450. サービス・オブジェクトは、サービス名(一般的に関数またはメソッド名)、
  451. パラメータ(名前、型と位置)や戻り値の型のような情報を含みます。
  452. めったに使われない機能ですが、
  453. 各々のサービスはそれ自身のターゲットとエンベロープを任意に持つことができます。
  454. </para>
  455. <para>
  456. 付属のクラスと関数のreflectionを用いて、
  457. <classname>Zend_Json_Server</classname>は舞台裏ですべてを実際に行ないます;
  458. クラスと関数自身への参照で提供することができないカスタム機能を準備する必要がある場合だけ、
  459. あなた自身のサービス・マップを生成しなければなりません。
  460. </para>
  461. <para>
  462. <classname>Zend_Json_Server_Smd</classname>での利用可能なメソッドを含みます:
  463. </para>
  464. <itemizedlist>
  465. <listitem><para><methodname>setOptions(array $options)</methodname>:
  466. オプション配列からSMDオブジェクトをセットアップします。
  467. ミューテーターのすべてを、キーとして使うことができます。
  468. (メソッドは 'set' で始まります)
  469. </para></listitem>
  470. <listitem><para><methodname>setTransport($transport)</methodname>:
  471. サービスにアクセスするために使われるトランスポートを設定します;
  472. 現行では POST だけがサポートされます。
  473. </para></listitem>
  474. <listitem><para><methodname>getTransport()</methodname>:
  475. 現行のサービストランスポートを取得します。
  476. </para></listitem>
  477. <listitem><para><methodname>setEnvelope($envelopeType)</methodname>:
  478. サービスにアクセスするために使われるであろうリクエスト・エンベロープを設定します。
  479. 現行では定数の
  480. <constant>Zend_Json_Server_Smd::ENV_JSONRPC_1</constant>及び
  481. <constant>Zend_Json_Server_Smd::ENV_JSONRPC_2</constant>をサポートします。
  482. </para></listitem>
  483. <listitem><para><methodname>getEnvelope()</methodname>:
  484. 現行のリクエスト・エンベロープを取得します。
  485. </para></listitem>
  486. <listitem><para><methodname>setContentType($type)</methodname>:
  487. リクエストが使うであろうコンテンツタイプを設定します。
  488. (デフォルトでは、これは 'application/json' です)
  489. </para></listitem>
  490. <listitem><para><methodname>getContentType()</methodname>:
  491. サービスにリクエストするための、現行のコンテンツタイプを取得します。
  492. </para></listitem>
  493. <listitem><para><methodname>setTarget($target)</methodname>:
  494. サービスのための<acronym>URL</acronym>エンドポイントを設定します。
  495. </para></listitem>
  496. <listitem><para><methodname>getTarget()</methodname>:
  497. サービスのための<acronym>URL</acronym>エンドポイントを取得します。
  498. </para></listitem>
  499. <listitem><para><methodname>setId($id)</methodname>:
  500. 一般的に、(ターゲットと同じく)これはサービスの<acronym>URL</acronym>エンドポイントです。
  501. </para></listitem>
  502. <listitem><para><methodname>getId()</methodname>:
  503. サービスIDを取得します。
  504. (一般的に、サービスの<acronym>URL</acronym>エンドポイントです)
  505. </para></listitem>
  506. <listitem><para><methodname>setDescription($description)</methodname>:
  507. サービスの定義を設定します。
  508. (一般的に、サービスの目的を説明する物語の情報です)
  509. </para></listitem>
  510. <listitem><para><methodname>getDescription()</methodname>:
  511. サービスの定義を取得します。
  512. </para></listitem>
  513. <listitem><para><methodname>setDojoCompatible($flag)</methodname>:
  514. SMDがDojoツールキットと互換かどうか示すフラグを設定します。
  515. trueの場合、生成された<acronym>JSON</acronym> SMDは、
  516. DojoのJSON-RPCクライアントが期待する形式に従ってフォーマットされます。
  517. </para></listitem>
  518. <listitem><para><methodname>isDojoCompatible()</methodname>:
  519. Dojo互換性フラグの値を返します。
  520. (デフォルトではfalseです)
  521. </para></listitem>
  522. <listitem><para><methodname>addService($service)</methodname>:
  523. マップするサービスを追加します。
  524. <classname>Zend_Json_Server_Smd_Service</classname>のコンストラクタに渡す情報の配列か、
  525. またはそのクラスのインスタンスでしょう。
  526. </para></listitem>
  527. <listitem><para><methodname>addServices(array $services)</methodname>:
  528. 一度に複数のサービスを追加します。
  529. </para></listitem>
  530. <listitem><para><methodname>setServices(array $services)</methodname>:
  531. 一度に複数のサービスを設定します。
  532. 以前に設定されたサービスを全て上書きします。
  533. </para></listitem>
  534. <listitem><para><methodname>getService($name)</methodname>:
  535. 名前でサービスを取得します。
  536. </para></listitem>
  537. <listitem><para><methodname>getServices()</methodname>:
  538. 付属のサービスを全て取得します。
  539. </para></listitem>
  540. <listitem><para><methodname>removeService($name)</methodname>:
  541. マップからサービスを除去します。
  542. </para></listitem>
  543. <listitem><para><methodname>toArray()</methodname>:
  544. サービスマップを配列にキャストします。
  545. </para></listitem>
  546. <listitem><para><methodname>toDojoArray()</methodname>:
  547. サービスマップをDojoツールキット互換の配列にキャストします。
  548. </para></listitem>
  549. <listitem><para><methodname>toJson()</methodname>:
  550. サービスマップを<acronym>JSON</acronym>表現にキャストします。
  551. </para></listitem>
  552. </itemizedlist>
  553. <para>
  554. <classname>Zend_Json_Server_Smd_Service</classname>には下記のメソッドがあります:
  555. </para>
  556. <itemizedlist>
  557. <listitem><para><methodname>setOptions(array $options)</methodname>:
  558. 配列からオブジェクトの状態を設定します。
  559. どのミューテーター(メソッドは 'set' で始まります)でもキーとして使われ、
  560. このメソッドを通じて設定されるでしょう。
  561. </para></listitem>
  562. <listitem><para><methodname>setName($name)</methodname>:
  563. サービス名を設定します。
  564. (一般的には、関数やメソッドの名前)
  565. </para></listitem>
  566. <listitem><para><methodname>getName()</methodname>:
  567. サービス名を取得します。
  568. </para></listitem>
  569. <listitem><para><methodname>setTransport($transport)</methodname>:
  570. サービスのトランスポートを設定します。
  571. (現行では、<classname>Zend_Json_Server_Smd</classname>によりサポートされる
  572. トランスポートのみ許可されます)
  573. </para></listitem>
  574. <listitem><para><methodname>getTransport()</methodname>: Retrieve the
  575. current transport.</para></listitem>
  576. <listitem><para><methodname>setTarget($target)</methodname>:
  577. サービスの<acronym>URL</acronym>エンドポイントを設定します。
  578. (一般的には、サービスが付与される全体的なSMDとこれは同じです。)
  579. </para></listitem>
  580. <listitem><para><methodname>getTarget()</methodname>:
  581. サービスの<acronym>URL</acronym>エンドポイントを取得します。
  582. </para></listitem>
  583. <listitem><para><methodname>setEnvelope($envelopeType)</methodname>:
  584. サービスのエンベロープタイプを設定します。
  585. (現行では、<classname>Zend_Json_Server_Smd</classname>によりサポートされる
  586. エンベロープのみ許可されます)
  587. </para></listitem>
  588. <listitem><para><methodname>getEnvelope()</methodname>:
  589. サービスのエンベロープタイプを取得します。
  590. </para></listitem>
  591. <listitem><para><code>addParam($type, array $options = array(),
  592. $order = null)</code>:
  593. サービスにパラメータを追加します。
  594. デフォルトで、パラメータ型だけは必要です。
  595. しかしながら、下記のオプションのように、指令を与えたいかもしれません:
  596. </para>
  597. <itemizedlist>
  598. <listitem><para><emphasis>name</emphasis>:
  599. パラメータ名
  600. </para></listitem>
  601. <listitem><para><emphasis>optional</emphasis>:
  602. パラメータが任意か否か
  603. </para></listitem>
  604. <listitem><para><emphasis>default</emphasis>:
  605. パラメータの既定値
  606. </para></listitem>
  607. <listitem><para><emphasis>description</emphasis>:
  608. パラメータを記述するテキスト
  609. </para></listitem>
  610. </itemizedlist>
  611. </listitem>
  612. <listitem><para><methodname>addParams(array $params)</methodname>:
  613. 一度にいくつかのパラメータを追加します;
  614. 各々のパラメータは、最小限、パラメータ型を記述する '型' 、
  615. さらに任意で '順序' キーを含む連想配列でなければなりません。
  616. その他の全てのキーは<methodname>addOption()</methodname>に
  617. <varname>$options</varname>として渡されます。
  618. </para></listitem>
  619. <listitem><para><methodname>setParams(array $params)</methodname>:
  620. 一度に複数のパラメーターを設定します。
  621. 既存のパラメータを全て上書きします。
  622. </para></listitem>
  623. <listitem><para><methodname>getParams()</methodname>:
  624. 現行で設定されているパラメータを全て取得します。
  625. </para></listitem>
  626. <listitem><para><methodname>setReturn($type)</methodname>:
  627. サービスの返り値の型を設定します。
  628. </para></listitem>
  629. <listitem><para><methodname>getReturn()</methodname>:
  630. サービスの返り値の型を取得します。
  631. </para></listitem>
  632. <listitem><para><methodname>toArray()</methodname>:
  633. サービスを配列にキャストします。
  634. </para></listitem>
  635. <listitem><para><methodname>toJson()</methodname>:
  636. サービスを<acronym>JSON</acronym>表現にキャストします。
  637. </para></listitem>
  638. </itemizedlist>
  639. </sect3>
  640. </sect2>
  641. </sect1>
  642. <!--
  643. vim:se ts=4 sw=4 et:
  644. -->