Zend_Controller-Modular.xml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.controller.modular">
  5. <title>モジュラーディレクトリ構造の規約の使用</title>
  6. <sect2 id="zend.controller.modular.introduction">
  7. <title>導入</title>
  8. <para>
  9. モジュラーディレクトリ構造の規約 (The Conventional Modular directory structure)
  10. により、さまざまな <acronym>MVC</acronym> アプリケーションを自己完結した単位にまとめることができます。
  11. また、それをさまざまなフロントコントローラで再利用できるようになります。
  12. このディレクトリ構造は、次のようになります。
  13. </para>
  14. <programlisting language="txt"><![CDATA[
  15. docroot/
  16. index.php
  17. application/
  18. default/
  19. controllers/
  20. IndexController.php
  21. FooController.php
  22. models/
  23. views/
  24. scripts/
  25. index/
  26. foo/
  27. helpers/
  28. filters/
  29. blog/
  30. controllers/
  31. IndexController.php
  32. models/
  33. views/
  34. scripts/
  35. index/
  36. helpers/
  37. filters/
  38. news/
  39. controllers/
  40. IndexController.php
  41. ListController.php
  42. models/
  43. views/
  44. scripts/
  45. index/
  46. list/
  47. helpers/
  48. filters/
  49. ]]></programlisting>
  50. <para>
  51. この考え方では、モジュール名が、
  52. その中に含まれるコントローラのプレフィックスとなります。
  53. 上の例には、三つのモジュールコントローラ
  54. '<classname>Blog_IndexController</classname>'、'<classname>News_IndexController</classname>' および
  55. '<classname>News_ListController</classname>' が含まれます。また、グローバルコントローラも
  56. '<classname>IndexController</classname>' と '<classname>FooController</classname>' の二つが定義されています。
  57. これらは名前空間に属しません。この章のサンプルでは、
  58. ここで示したディレクトリ構造を使用します。
  59. </para>
  60. <note>
  61. <title>デフォルトモジュールでは名前空間を使用しない</title>
  62. <para>
  63. デフォルトモジュールでは、コントローラは
  64. 名前空間プレフィックスを必要としないことに注意しましょう。
  65. したがって、上の例ではデフォルトモジュールのコントローラには
  66. 'Default_' は不要です。そのベースコントローラ名である
  67. '<classname>IndexController</classname>' および
  68. '<classname>FooController</classname>' にもとづいて単純にディスパッチされます。
  69. しかし、それ以外のモジュールでは名前空間プレフィックスを使用します。
  70. </para>
  71. </note>
  72. <para>
  73. それでは、Zend Framework の <acronym>MVC</acronym> コンポーネントを使用して
  74. これらのディレクトリ配置を実装するにはどうすればいいのでしょうか?
  75. </para>
  76. </sect2>
  77. <sect2 id="zend.controller.modular.directories">
  78. <title>モジュールコントローラディレクトリの指定</title>
  79. <para>
  80. モジュールを使用するための第一歩となるのが、
  81. フロントコントローラでのコントローラディレクトリの設定方法を変更することです。
  82. 基本的な <acronym>MVC</acronym> 版では、配列あるいは文字列を
  83. <methodname>setControllerDirectory()</methodname> に渡すか、
  84. あるいはパスを <methodname>addControllerDirectory()</methodname>
  85. に渡していました。モジュールを使用する場合は、
  86. これらのメソッドコールを少々変更する必要があります。
  87. </para>
  88. <para>
  89. <methodname>setControllerDirectory()</methodname> では、連想配列を渡す必要があります。
  90. 連想配列のキーにはモジュール名、そしてその値としてディレクトリのパスを指定します。
  91. 特別な名前 <property>default</property> をキーにすると、グローバルコントローラ
  92. (モジュール名前空間を必要としないもの) を指定できます。
  93. すべてのエントリは、ひとつのパスをさす文字列のキーを含まなければなりません。
  94. また、<property>default</property> というキーが必ず存在しなければなりません。
  95. 次の例のようになります。
  96. </para>
  97. <programlisting language="php"><![CDATA[
  98. $front->setControllerDirectory(array(
  99. 'default' => '/path/to/application/controllers',
  100. 'blog' => '/path/to/application/blog/controllers'
  101. ));
  102. ]]></programlisting>
  103. <para>
  104. <methodname>addControllerDirectory()</methodname> では、オプションの二番目の引数を受け付けます。
  105. モジュールを使用する際には、モジュール名を二番目の引数で渡します。
  106. 指定しない場合は、そのパスは <emphasis>default</emphasis> 名前空間に追加されます。
  107. 次の例のようになります。
  108. </para>
  109. <programlisting language="php"><![CDATA[
  110. $front->addControllerDirectory('/path/to/application/news/controllers',
  111. 'news');
  112. ]]></programlisting>
  113. <para>
  114. 結局のところ、モジュールのディレクトリを設定する一番お手軽な方法は、
  115. 共通のモジュールディレクトリの配下に同じ構造でモジュールを保持しておくことです。
  116. これを行うのが <methodname>addModuleDirectory()</methodname> メソッドです。
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. /**
  120. * 次のような構造を想定しています
  121. * application/
  122. * modules/
  123. * default/
  124. * controllers/
  125. * foo/
  126. * controllers/
  127. * bar/
  128. * controllers/
  129. */
  130. $front->addModuleDirectory('/path/to/application/modules');
  131. ]]></programlisting>
  132. <para>
  133. 上の例は <emphasis>default</emphasis>、
  134. <emphasis>foo</emphasis> および <emphasis>bar</emphasis> というモジュールを定義しており、
  135. それぞれのモジュール内に <filename>controllers/</filename>
  136. ディレクトリを保持しています。
  137. </para>
  138. <para>
  139. モジュール内のコントローラディレクトリ名を変更するには、
  140. <methodname>setModuleControllerDirectoryName()</methodname> を使用します。
  141. </para>
  142. <programlisting language="php"><![CDATA[
  143. /**
  144. * コントローラのディレクトリを、次のように 'con' に変更します
  145. * application/
  146. * modules/
  147. * default/
  148. * con/
  149. * foo/
  150. * con/
  151. * bar/
  152. * con/
  153. */
  154. $front->setModuleControllerDirectoryName('con');
  155. $front->addModuleDirectory('/path/to/application/modules');
  156. ]]></programlisting>
  157. <note>
  158. <para>
  159. モジュール内でコントローラディレクトリを使用しない場合は、
  160. <methodname>setModuleControllerDirectoryName()</methodname>
  161. に空の文字列を指定します。
  162. </para>
  163. </note>
  164. </sect2>
  165. <sect2 id="zend.controller.modular.router">
  166. <title>モジュールへのルーティング</title>
  167. <para>
  168. <classname>Zend_Controller_Router_Rewrite</classname> のデフォルトのルートは
  169. <classname>Zend_Controller_Router_Route_Module</classname> 型のオブジェクトです。
  170. このルートは、以下のいずれかの形式のルーティングを行います。
  171. </para>
  172. <itemizedlist>
  173. <listitem><para><code>:module/:controller/:action/*</code></para></listitem>
  174. <listitem><para><code>:controller/:action/*</code></para></listitem>
  175. </itemizedlist>
  176. <para>
  177. 言い換えると、これは、指定したコントローラとアクション
  178. あるいはその先頭にモジュールをつけたものにマッチします。
  179. このマッチング規則からわかることは、
  180. フロントコントローラとディスパッチャに渡された配列で指定した
  181. コントローラディレクトリの配列に同名のキーがある場合にのみ
  182. モジュールにマッチするということです。
  183. </para>
  184. </sect2>
  185. <sect2 id="zend.controller.modular.defaultcontroller">
  186. <title>モジュールあるいはグローバルのデフォルトコントローラ</title>
  187. <para>
  188. デフォルトのルータでは、コントローラが <acronym>URL</acronym> で指定されなかった場合には
  189. デフォルトのコントローラ (特に指定しなければ <classname>IndexController</classname>)
  190. を使用します。モジュール対応のコントローラにおいて、
  191. モジュールのみを指定してコントローラを指定しなかった場合は、
  192. ディスパッチャはまず最初にモジュールパス内のデフォルトコントローラを探します。
  193. 次に、グローバル名前空間 'default' にあるデフォルトコントローラを探します。
  194. </para>
  195. <para>
  196. デフォルトは常にグローバル名前空間のほうにしたい場合は、
  197. フロントコントローラでパラメータ
  198. <varname>$useDefaultControllerAlways</varname> を指定します。
  199. </para>
  200. <programlisting language="php"><![CDATA[
  201. $front->setParam('useDefaultControllerAlways', true);
  202. ]]></programlisting>
  203. </sect2>
  204. </sect1>
  205. <!--
  206. vim:se ts=4 sw=4 et:
  207. -->