Zend_Controller-Basics.xml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.controller.basics">
  5. <title>Zend_Controller の基本</title>
  6. <para>
  7. <classname>Zend_Controller</classname> は軽量で部品化されており、拡張しやすいように設計されています。
  8. この設計は、柔軟性および利用者に対する自由度を確保するための最低限のものであり、
  9. <classname>Zend_Controller</classname> を使用して構築したシステムは、
  10. ほぼ同じようなコード配置・規約を共有できます。
  11. </para>
  12. <para>
  13. 次の図は処理の流れを表したものです。また、詳細についてはそれ以降で説明しています。
  14. </para>
  15. <para>
  16. <inlinegraphic width="483" scale="100" align="center" valign="middle"
  17. fileref="figures/zend.controller.basics.png" format="PNG" />
  18. </para>
  19. <para>
  20. <classname>Zend_Controller</classname> の処理の流れは、
  21. いくつかの部品にわかれて実装されています。
  22. これらの部品のすべてを完璧に理解する必要はありませんが、
  23. 処理の概要を知っておくことは有用です。
  24. </para>
  25. <itemizedlist>
  26. <listitem>
  27. <para>
  28. <classname>Zend_Controller_Front</classname> は、
  29. <classname>Zend_Controller</classname> の処理全体を取りまとめます。
  30. FrontController パターンであるといえます。
  31. サーバから受け取ったすべてのリクエストを <classname>Zend_Controller_Front</classname>
  32. が処理し、最終的にリクエストを ActionController
  33. (<classname>Zend_Controller_Action</classname>) に委譲します。
  34. </para>
  35. </listitem>
  36. <listitem>
  37. <para>
  38. <classname>Zend_Controller_Request_Abstract</classname>
  39. はリクエスト環境を表し、コントローラ名やアクション名
  40. そしてリクエストパラメータを設定したり取得したりする機能を提供します。
  41. さらに、アクションが <classname>Zend_Controller_Dispatcher</classname>
  42. でディスパッチされたかどうかを追跡する機能もあります。
  43. この抽象<emphasis>リクエストオブジェクト</emphasis>を拡張し、
  44. リクエスト情報をカプセル化します。それによって、
  45. ルータはリクエストの情報を取得して
  46. コントローラとアクションを決定できるようになります。
  47. </para>
  48. <para>
  49. デフォルトでは <classname>Zend_Controller_Request_Http</classname>
  50. が用いられます。これは、<acronym>HTTP</acronym> リクエスト環境全体へのアクセス機能を提供します。
  51. </para>
  52. </listitem>
  53. <listitem>
  54. <para>
  55. <classname>Zend_Controller_Router_Interface</classname> を使用してルータを定義します。
  56. ルーティングとは、リクエストの内容を調べて、
  57. そのリクエストを処理するコントローラとアクションを決定する処理のことです。
  58. このコントローラとアクション、そしてリクエストパラメータがリクエストオブジェクトに設定され、
  59. <classname>Zend_Controller_Dispatcher_Standard</classname> で処理されます。
  60. ルーティングが発生するのは一度だけ、
  61. つまり最初にリクエストを受け取ってから
  62. 最初のコントローラにディスパッチされるまでの間だけです。
  63. </para>
  64. <para>
  65. デフォルトのルータである <classname>Zend_Controller_Router_Rewrite</classname> は、
  66. <classname>Zend_Controller_Request_Http</classname> で指定された <acronym>URI</acronym>
  67. を受け取ってそれを分解し、コントローラや
  68. アクション、そして <acronym>URL</acronym> に含まれたパスのパラメータを取得します。
  69. たとえば、<filename>http://localhost/foo/bar/key/value</filename>
  70. のような URL の場合は <emphasis>foo</emphasis> がコントローラ、
  71. <emphasis>bar</emphasis> がアクション、そしてパラメータ
  72. <emphasis>key</emphasis> の値として <emphasis>value</emphasis> を取得します。
  73. </para>
  74. <para>
  75. <classname>Zend_Controller_Router_Rewrite</classname>
  76. は、任意のパスにマッチさせることもできます。
  77. 詳細は <link
  78. linkend="zend.controller.router">
  79. ルータのドキュメント</link>
  80. を参照ください。
  81. </para>
  82. </listitem>
  83. <listitem>
  84. <para>
  85. <classname>Zend_Controller_Dispatcher_Interface</classname>
  86. を使用してディスパッチャを定義します。ディスパッチとは、
  87. コントローラとアクションをリクエストオブジェクトから受け取り、
  88. それを実際のコントローラファイル/クラスとメソッドに対応させる処理のことです。
  89. コントローラやアクションが存在しない場合は、
  90. デフォルトのコントローラやアクションにディスパッチします。
  91. </para>
  92. <para>
  93. 実際のディスパッチ処理では、
  94. コントローラクラスのインスタンスの作成と
  95. そのクラスのアクションメソッドのコールを行います。
  96. ルーティングは一度しか発生しませんが、
  97. それとは異なりディスパッチは繰り返し発生します。
  98. リクエストオブジェクトのディスパッチ状態がリセットされるとループが再開され、
  99. 現在リクエストオブジェクトに設定されているアクションがコールされます。
  100. リクエストオブジェクトのディスパッチ状態が (<constant>TRUE</constant> に)
  101. 設定された状態でループが終了すると、処理が終了します。
  102. </para>
  103. <para>
  104. デフォルトのディスパッチャは
  105. <classname>Zend_Controller_Dispatcher_Standard</classname> です。
  106. これは、MixedCasedClasses 形式の名前の最後に
  107. Controller がついたクラスをコントローラとして使用し、
  108. アクションメソッドの名前は camelCasedMethods
  109. 形式 (最後に Action をつける) となります。たとえば
  110. <methodname>FooController::barAction()</methodname>
  111. のような場合、コントローラは
  112. <emphasis>foo</emphasis>、アクションは <emphasis>bar</emphasis>
  113. となります。
  114. </para>
  115. <note>
  116. <title>大文字小文字の命名規約</title>
  117. <para>
  118. 人はみな、リンクをタイプする際に大文字小文字の区別をあまり気にしないものです。
  119. Zend Framework では、パス情報をすべて小文字に正規化します。
  120. これはもちろん、
  121. コントローラ名やアクション名を決める際やリンクする場合にも影響を及ぼします。
  122. </para>
  123. <para>
  124. コントローラクラスやアクションメソッドの名前に
  125. MixedCase あるいは camelCase の単語を複数使用したい場合は、
  126. URL 上での単語の区切り文字として '-' あるいは
  127. '.' のいずれかを使用しなければなりません
  128. (とは言え、ここで使用する文字は変更できます)。
  129. </para>
  130. <para>
  131. たとえば、アクションを
  132. <methodname>FooBarController::bazBatAction()</methodname>
  133. で定義したとすると、対応する URL は
  134. <filename>/foo-bar/baz-bat</filename>
  135. あるいは <filename>/foo.bar/baz.bat</filename> となります。
  136. </para>
  137. </note>
  138. </listitem>
  139. <listitem>
  140. <para>
  141. <classname>Zend_Controller_Action</classname> はコントローラの基底コンポーネントです。
  142. 各コントローラはこの <classname>Zend_Controller_Action</classname>
  143. クラスを継承して作成します。このクラスではアクションメソッドを定義します。
  144. </para>
  145. </listitem>
  146. <listitem>
  147. <para>
  148. <classname>Zend_Controller_Response_Abstract</classname>
  149. は基底レスポンスクラスで、アクションコントローラからの応答内容を収集し、
  150. それをレスポンスとして返します。これはヘッダと本文の両方を収集します。
  151. </para>
  152. <para>
  153. デフォルトのレスポンスクラスは
  154. <classname>Zend_Controller_Response_Http</classname> で、
  155. これは <acronym>HTTP</acronym> 環境での使用に適しています。
  156. </para>
  157. </listitem>
  158. </itemizedlist>
  159. <para>
  160. <classname>Zend_Controller</classname> の処理の流れは比較的シンプルです。
  161. <classname>Zend_Controller_Front</classname> がリクエストを受け取り、
  162. <classname>Zend_Controller_Router_Rewrite</classname> をコールして、
  163. 配送先となるコントローラ (そしてコントローラ内のアクション)
  164. を決定します。<classname>Zend_Controller_Router_Rewrite</classname> は <acronym>URI</acronym>
  165. を分解し、リクエストからコントローラ名とアクション名を取得します。
  166. その後、<classname>Zend_Controller_Front</classname> はディスパッチループに突入します。
  167. まず <classname>Zend_Controller_Dispatcher_Standard</classname> をコールしてそこにリクエストを渡し、
  168. リクエストで指定されたコントローラとアクションを取得します
  169. (あるいはデフォルトを使用します)。
  170. コントローラが終了すると、処理は <classname>Zend_Controller_Front</classname>
  171. に戻ります。リクエストのディスパッチ状態がリセットされ、
  172. 別のコントローラをディスパッチするように指示された場合は、
  173. ループが続けられて次の配送処理が行われます。
  174. それ以外の場合は、処理がそこで終了します。それ以外の場合は、
  175. 処理が終了します。
  176. </para>
  177. </sect1>
  178. <!--
  179. vim:se ts=4 sw=4 et:
  180. -->