Zend_Controller-Migration.xml 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15850 -->
  4. <sect1 id="zend.controller.migration">
  5. <title>以前のバージョンからの移行</title>
  6. <para>
  7. MVC コンポーネントの API は以前とは変更されました。
  8. 初期のバージョンから Zend Framework を使用しておられるかたは、
  9. 以下のガイドラインにしたがってスクリプトを変更し、
  10. 新しい仕組みに対応させてください。
  11. </para>
  12. <sect2 id="zend.controller.migration.fromoneseventooneeight">
  13. <title>1.7.x から 1.8.0 以降への移行</title>
  14. <sect3 id="zend.controller.migration.fromoneseventooneeight.router">
  15. <title>標準のルートの変更</title>
  16. <para>
  17. 新しい標準ルートでは翻訳セグメントが使用できるようになったため、
  18. ルートのセグメントの先頭にある <code>@</code> は特殊文字と解釈されるようになりました。
  19. この文字を静的セグメント内で使用するには、前にもうひとつ
  20. <code>@</code> をつけてエスケープする必要があります。
  21. また、<code>:</code> も同様です。
  22. </para>
  23. </sect3>
  24. </sect2>
  25. <sect2 id="zend.controller.migration.fromonesixtooneseven">
  26. <title>1.6.x から 1.7.0 以降への移行</title>
  27. <sect3 id="zend.controller.migration.fromonesixtooneseven.dispatcher">
  28. <title>ディスパッチャインターフェイスの変更</title>
  29. <para>
  30. ユーザからの指摘により、
  31. <classname>Zend_Controller_Action_Helper_ViewRenderer</classname>
  32. が使っているディスパッチャ抽象クラスのメソッドの中で
  33. ディスパッチャインターフェイスに存在しないものがあることに気づきました。
  34. 次のメソッドを追加し、
  35. 自作のディスパッチャが同梱の実装と共存できるようにしています。
  36. </para>
  37. <itemizedlist>
  38. <listitem><para>
  39. <code>formatModuleName()</code>:
  40. リクエストオブジェクト内に格納されたりしている生のコントローラ名を受け取り、
  41. それを再フォーマットして
  42. <classname>Zend_Controller_Action</classname> を継承した適切なクラス名にします。
  43. </para></listitem>
  44. </itemizedlist>
  45. </sect3>
  46. </sect2>
  47. <sect2 id="zend.controller.migration.fromoneohtoonesix">
  48. <title>1.5.x から 1.6.0 以降への移行</title>
  49. <sect3 id="zend.controller.migration.fromoneohtoonesix.dispatcher">
  50. <title>ディスパッチャインターフェイスの変更</title>
  51. <para>
  52. <classname>Zend_Controller_Front</classname> と
  53. <classname>Zend_Controller_Router_Route_Module</classname>
  54. は、ディスパッチャインターフェイスにないメソッドを使用していました。
  55. 次の 3 つのメソッドを追加し、
  56. 自作のディスパッチャが同梱の実装と共存できるようにしています。
  57. </para>
  58. <itemizedlist>
  59. <listitem><para>
  60. <code>getDefaultModule()</code>:
  61. デフォルトモジュールの名前を返します。
  62. </para></listitem>
  63. <listitem><para>
  64. <code>getDefaultControllerName()</code>:
  65. デフォルトコントローラの名前を返します。
  66. </para></listitem>
  67. <listitem><para>
  68. <code>getDefaultAction()</code>:
  69. デフォルトアクションの名前を返します。
  70. </para></listitem>
  71. </itemizedlist>
  72. </sect3>
  73. </sect2>
  74. <sect2 id="zend.controller.migration.fromoneohtoonefive">
  75. <title>1.0.x から 1.5.0 以降への移行</title>
  76. <para>
  77. 基本的な機能は同じでドキュメント化されている機能も変わりませんが、
  78. ひとつだけ、<emphasis>ドキュメント化されていない</emphasis>
  79. "機能" が変更されました。
  80. </para>
  81. <para>
  82. URL の書き方としてドキュメント化されている方法は、
  83. camelCased 形式の名前のアクションを使用するために
  84. 単語の区切り文字を使用するというものです。デフォルトの区切り文字は
  85. '.' あるいは '-' ですが、ディスパッチャの設定で変更することができます。
  86. ディスパッチャは内部でアクション名を小文字に変換し、
  87. 単語の区切り文字をもとに camelCasing 形式のアクションメソッド名を作成します。
  88. しかし、PHP の関数名は大文字小文字を区別しないので、URL 自体を
  89. camelCasing 形式で書くこともできます。
  90. この場合でも、ディスパッチャは URL を同じアクションメソッドに解決します。
  91. たとえば 'camel-cased' はディスパッチャによって
  92. 'camelCasedAction' になります。一方 'camelCased' は
  93. 'camelcasedAction' となります。PHP では大文字小文字を細かく区別しないため、
  94. これらはどちらも同じメソッドを実行することになります。
  95. </para>
  96. <para>
  97. これは、ViewRenderer がビュースクリプトを解決する際に問題を引き起こします。
  98. ドキュメントに記載されている正式な方法は、
  99. 単語の区切りをすべてダッシュに変換して単語は小文字にするというものです。
  100. こうすればアクションとビュースクリプトの関連が明確になり、
  101. 小文字への正規化でスクリプトが見つかることが確実となります。
  102. しかし、アクション 'camelCased' がコールされて解決された場合は、
  103. 単語の区切りはもう存在しません。そして ViewRenderer は
  104. 'camel-cased.phtml' ではない別のファイル -- 'camelcased.phtml'
  105. を探してしまうのです。
  106. </para>
  107. <para>
  108. 中にはこの "機能" を使用している開発者もいるようますが、
  109. これは決して意図した機能ではありません。
  110. 1.5.0 のツリーでは、ViewRenderer はこの方式の解決を行わなくなりました。
  111. これでアクションとビュースクリプトの結びつきが確実になったわけです。
  112. まず、ディスパッチャはアクション名の大文字小文字をきちんと区別するようになります。
  113. つまり、camelCasing 形式を使用したアクションの解決先は、
  114. 単語の区切りを使用した ('camel-casing') 場合とは違うものになるということです。
  115. これで、ViewRenderer がビュースクリプトを解決する際には
  116. 区切り文字を使用したアクションのみを使用することになります。
  117. </para>
  118. <para>
  119. 今までこの "機能" に頼っていた人たちは、
  120. 以下のいずれかの方法で対応します。
  121. </para>
  122. <itemizedlist>
  123. <listitem><para>
  124. 一番いい方法: ビュースクリプトの名前を変更する。
  125. 利点: 前方互換性。欠点: もし対象となるビュースクリプトが多い場合は、
  126. 多くのファイルの名前を変更しなければならなくなります。
  127. </para></listitem>
  128. <listitem>
  129. <para>
  130. その次にいい方法: ViewRenderer はビュースクリプトの解決を
  131. <classname>Zend_Filter_Inflector</classname> に委譲しています。
  132. インフレクタのルールを変更し、
  133. アクションの単語間をダッシュで区切らないようにします。
  134. </para>
  135. <programlisting language="php"><![CDATA[
  136. $viewRenderer =
  137. Zend_Controller_Action_HelperBroker::getStaticHelper('viewRenderer');
  138. $inflector = $viewRenderer->getInflector();
  139. $inflector->setFilterRule(':action', array(
  140. new Zend_Filter_PregReplace(
  141. '#[^a-z0-9' . preg_quote(DIRECTORY_SEPARATOR, '#') . ']+#i',
  142. ''
  143. ),
  144. 'StringToLower'
  145. ));
  146. ]]></programlisting>
  147. <para>
  148. 上のコードは、インフレクタを変更して単語をダッシュで区切らないようにしています。
  149. もし実際のビュースクリプト名を camelCased にしたいのなら、さらに
  150. 'StringToLower' フィルタも削除することになるでしょう。
  151. </para>
  152. <para>
  153. ビュースクリプトの名前を変えるのが面倒だったり
  154. 時間がかかったりする場合は、
  155. もしあまり時間を割けないのならこの方法が最適です。
  156. </para>
  157. </listitem>
  158. <listitem>
  159. <para>
  160. あまりお勧めしない方法: ディスパッチャに camelCased
  161. 形式のアクションをディスパッチさせるよう、フロントコントローラのフラグ
  162. 'useCaseSensitiveActions' を設定します。
  163. </para>
  164. <programlisting language="php"><![CDATA[
  165. $front->setParam('useCaseSensitiveActions', true);
  166. ]]></programlisting>
  167. <para>
  168. これで camelCasing 形式の URL を使えるようになり、
  169. 単語の区切り文字を使用した場合と同じアクションに解決されるようになります。
  170. しかし、もともと抱えていた問題も残ったままとなってしまいます。
  171. できれば先ほどのふたつのうちのいずれかを使用したほうがいいでしょう。
  172. </para>
  173. <para>
  174. このフラグを使用していると、
  175. 将来このフラグが廃止予定になったときに notice が発生することになります。
  176. </para>
  177. </listitem>
  178. </itemizedlist>
  179. </sect2>
  180. <sect2 id="zend.controller.migration.fromzeroninethree">
  181. <title>0.9.3 から 1.0.0RC1 以降への移行</title>
  182. <para>
  183. 1.0.0RC1 での最大の変更点は、
  184. <link linkend="zend.controller.plugins.standard.errorhandler">ErrorHandler</link>
  185. プラグインと
  186. <link linkend="zend.controller.actionhelpers.viewrenderer">ViewRenderer</link>
  187. アクションヘルパーが追加され、デフォルトで有効となったことです。
  188. それぞれのドキュメントを熟読し、どのように動作するのかや
  189. 既存のアプリケーションに与える影響について確認しておきましょう。
  190. </para>
  191. <para>
  192. <code>ErrorHandler</code> プラグインは
  193. <code>postDispatch()</code> で動作するもので、
  194. 例外をチェックして指定したエラーハンドラコントローラに転送します。
  195. そのため、アプリケーション内にエラー処理用コントローラを含める必要があります。
  196. このプラグインを無効にするには、フロントコントローラのパラメータ
  197. <code>noErrorHandler</code> を設定します。
  198. </para>
  199. <programlisting language="php"><![CDATA[
  200. $front->setParam('noErrorHandler', true);
  201. ]]></programlisting>
  202. <para>
  203. <code>ViewRenderer</code> アクションヘルパーは、
  204. アクションコントローラへのビューの注入を自動的に行います。
  205. また、現在のアクションにもとづいたビュースクリプトを自動的にレンダリングします。
  206. ビュースクリプトをレンダリングせず、かつ転送やリダイレクトも行わないアクションがあった場合、
  207. これは問題になるでしょう。というのも、
  208. <code>ViewRenderer</code> はそんなアクションであっても
  209. アクション名をもとに自動的にビュースクリプトをレンダリングしようとするからです。
  210. </para>
  211. <para>
  212. もし既存のコードにそのようなものがあった場合の対応方法はいくつか考えられます。
  213. 一番手っ取り早いのは、フロントコントローラの起動時に
  214. <code>ViewRenderer</code> を無効にしてからディスパッチを行うことです。
  215. </para>
  216. <programlisting language="php"><![CDATA[
  217. // $front は Zend_Controller_Front のインスタンスであるとします
  218. $front->setParam('noViewRenderer', true);
  219. ]]></programlisting>
  220. <para>
  221. しかし、長い目で見ればこれはあまりよい作戦ではありません。
  222. 今後も新しいコードを書き続けるならなおさらです。
  223. </para>
  224. <para>
  225. <code>ViewRenderer</code> の機能を把握したら、コントローラのコードを見てみましょう。
  226. まず、アクションメソッド (名前が 'Action' で終わっているメソッド)
  227. を探し、その中でどんな処理をしているかを確認しましょう。
  228. もし次に挙げるいずれの内容も行っていない場合は、コードに手を加える必要があります。
  229. </para>
  230. <itemizedlist>
  231. <listitem><para><code>$this-&gt;render()</code> のコール</para></listitem>
  232. <listitem><para><code>$this-&gt;_forward()</code> のコール</para></listitem>
  233. <listitem><para><code>$this-&gt;_redirect()</code> のコール</para></listitem>
  234. <listitem><para><code>Redirector</code> アクションヘルパーのコール</para></listitem>
  235. </itemizedlist>
  236. <para>
  237. 一番簡単なのは、そのメソッド内で自動レンダリングを無効にすることです。
  238. </para>
  239. <programlisting language="php"><![CDATA[
  240. $this->_helper->viewRenderer->setNoRender();
  241. ]]></programlisting>
  242. <para>
  243. レンダリング、転送あるいはリダイレクトを行っているアクションメソッドがひとつもない場合は、
  244. 上で示したコードを <code>preDispatch()</code>
  245. メソッドあるいは <code>init()</code> メソッド内に書くといいでしょう。
  246. </para>
  247. <programlisting language="php"><![CDATA[
  248. public function preDispatch()
  249. {
  250. // ビュースクリプトの自動レンダリングを無効にします
  251. $this->_helper->viewRenderer->setNoRender()
  252. // .. 何かほかのことをします...
  253. }
  254. ]]></programlisting>
  255. <para>
  256. もしメソッド内で <code>render()</code> をコールしていて、
  257. <link linkend="zend.controller.modular">規約どおりのディレクトリ構造</link>
  258. を使用しているのなら、自動レンダリングを使用するようにコードを書き換えましょう。
  259. </para>
  260. <itemizedlist>
  261. <listitem>
  262. <para>
  263. ひとつのアクションで複数のビュースクリプトをレンダリングしている場合は、
  264. なにも変更する必要はありません。
  265. </para>
  266. </listitem>
  267. <listitem>
  268. <para>
  269. 何も引数を指定せずに <code>render()</code> をコールしている場合は、
  270. その行を削除します。
  271. </para>
  272. </listitem>
  273. <listitem>
  274. <para>
  275. 引数つきで <code>render()</code> をコールしていて、
  276. その後に何か処理をしたり複数のビュースクリプトを実行したりしていない場合は、
  277. その行を
  278. <code>$this-&gt;_helper-&gt;viewRenderer()</code>
  279. のように変更します。
  280. </para>
  281. </listitem>
  282. </itemizedlist>
  283. <para>
  284. 独自のディレクトリ構造を使用している場合は、
  285. ビューの基底パスやスクリプトのパスをメソッドで設定してから
  286. <code>ViewRenderer</code> を使用します。これらのメソッドについての詳細は
  287. <link linkend="zend.controller.actionhelpers.viewrenderer">ViewRenderer
  288. のドキュメント</link> を参照ください。
  289. </para>
  290. <para>
  291. ビューオブジェクトをレジストリから取得していたり
  292. ビューオブジェクトをカスタマイズしていたり、
  293. あるいはデフォルトとは異なるビューを使用している場合は、
  294. そのオブジェクトを <code>ViewRenderer</code>
  295. に注入するために次のようにします。
  296. これはいつでも好きなときに行えます。
  297. </para>
  298. <itemizedlist>
  299. <listitem>
  300. <para>
  301. フロントコントローラのインスタンスをディスパッチする前なら
  302. </para>
  303. <programlisting language="php"><![CDATA[
  304. // $view はすでに定義されているものとします
  305. $viewRenderer = new Zend_Controller_Action_Helper_ViewRenderer($view);
  306. Zend_Controller_Action_HelperBroker::addHelper($viewRenderer);
  307. ]]></programlisting>
  308. </listitem>
  309. <listitem>
  310. <para>
  311. 起動処理の中ならどこでも
  312. </para>
  313. <programlisting language="php"><![CDATA[
  314. $viewRenderer =
  315. Zend_Controller_Action_HelperBroker::getStaticHelper('viewRenderer');
  316. $viewRenderer->setView($view);]]></programlisting>
  317. </listitem>
  318. </itemizedlist>
  319. <para>
  320. <code>ViewRenderer</code> を変更するにはさまざまな方法があります。
  321. たとえばレンダリングするビュースクリプトを別のものに変更したり
  322. ビュースクリプトパスの置換可能な要素(サフィックスを含む)
  323. を置換する内容を指定したり、使用するレスポンスセグメントを選択したりなどのことができます。
  324. 規約どおりのディレクトリ構造以外を使用する場合は、
  325. <code>ViewRenderer</code> でのパスの決定方法を変更することもできます。
  326. </para>
  327. <para>
  328. <code>ErrorHandler</code> および <code>ViewRenderer</code>
  329. は今やコア機能として組み込まれているので、
  330. 既存のコードについてもできるだけこれに適合するようにすることをお勧めします。
  331. </para>
  332. </sect2>
  333. <sect2 id="zend.controller.migration.fromzeroninetwo">
  334. <title>0.9.2 から 0.9.3 以降への移行</title>
  335. <para>
  336. 0.9.3 では <link
  337. linkend="zend.controller.actionhelpers">アクションヘルパー</link>
  338. が利用できるようになりました。この変更にともない、以下のメソッドが削除され、
  339. <link linkend="zend.controller.actionhelpers.redirector">リダイレクタ
  340. アクションヘルパー</link> に組み込まれました。
  341. </para>
  342. <itemizedlist>
  343. <listitem>
  344. <para>
  345. <code>setRedirectCode()</code> の代わりに
  346. <classname>Zend_Controller_Action_Helper_Redirector::setCode()</classname>
  347. を使用します。
  348. </para>
  349. </listitem>
  350. <listitem>
  351. <para>
  352. <code>setRedirectPrependBase()</code> の代わりに
  353. <classname>Zend_Controller_Action_Helper_Redirector::setPrependBase()</classname>
  354. を使用します。
  355. </para>
  356. </listitem>
  357. <listitem>
  358. <para>
  359. <code>setRedirectExit()</code> の代わりに
  360. <classname>Zend_Controller_Action_Helper_Redirector::setExit()</classname>
  361. を使用します。
  362. </para>
  363. </listitem>
  364. </itemizedlist>
  365. <para>
  366. ヘルパーオブジェクトの取得方法や操作方法についての詳細は
  367. <link linkend="zend.controller.actionhelpers">アクションヘルパーのドキュメント</link> を、
  368. そしてリダイレクトの設定方法(新しいメソッドなど)についての詳細は
  369. <link linkend="zend.controller.actionhelpers.redirector">リダイレクタ
  370. アクションヘルパーのドキュメント</link> を参照ください。
  371. </para>
  372. </sect2>
  373. <sect2 id="zend.controller.migration.fromzerosix">
  374. <title>0.6.0 から 0.8.0 以降への移行</title>
  375. <para>
  376. 前回変更された、もっとも基本的な MVC コンポーネントの使用法は、そのまま同じです。
  377. </para>
  378. <programlisting language="php"><![CDATA[
  379. Zend_Controller_Front::run('/path/to/controllers');
  380. ]]></programlisting>
  381. <para>
  382. しかし、ディレクトリ構造を見直し、いくつかのコンポーネントが削除されました。
  383. また、名前が変更されたり新たに追加されたものもあります。以下にそれらをまとめます。
  384. </para>
  385. <itemizedlist>
  386. <listitem>
  387. <para>
  388. <classname>Zend_Controller_Router</classname> は削除されました。
  389. かわりに rewrite ルータを使用してください。
  390. </para>
  391. </listitem>
  392. <listitem>
  393. <para>
  394. <classname>Zend_Controller_RewriteRouter</classname> は
  395. <classname>Zend_Controller_Router_Rewrite</classname> という名前に変わり、
  396. このフレームワークの標準ルータに格上げされました。
  397. <classname>Zend_Controller_Front</classname> は、
  398. 特に別のルータを指定しない限りこのルータをデフォルトで使用します。
  399. </para>
  400. </listitem>
  401. <listitem>
  402. <para>
  403. rewrite ルータで使用する、新しいルートクラスが追加されました。名前は
  404. <classname>Zend_Controller_Router_Route_Module</classname> です。
  405. これは MVC で使用するデフォルトのルートのほかに、<link
  406. linkend="zend.controller.modular">コントローラモジュール
  407. </link> をサポートしています。
  408. </para>
  409. </listitem>
  410. <listitem>
  411. <para>
  412. <classname>Zend_Controller_Router_StaticRoute</classname> は
  413. <classname>Zend_Controller_Router_Route_Static</classname> という名前に変わりました。
  414. </para>
  415. </listitem>
  416. <listitem>
  417. <para>
  418. <classname>Zend_Controller_Dispatcher</classname> は
  419. <classname>Zend_Controller_Dispatcher_Standard</classname> という名前に変わりました。
  420. </para>
  421. </listitem>
  422. <listitem>
  423. <para>
  424. <classname>Zend_Controller_Action::_forward()</classname> の引数が変わりました。
  425. 新しいシグネチャは次のとおりです。
  426. </para>
  427. <programlisting language="php"><![CDATA[
  428. final protected function _forward($action,
  429. $controller = null,
  430. $module = null,
  431. array $params = null);
  432. ]]></programlisting>
  433. <para>
  434. <varname>$action</varname> は常に必須です。
  435. コントローラを指定しなかった場合は、
  436. 現在のコントローラ内のアクションであるとみなされます。
  437. <varname>$controller</varname> を指定しなかった場合は、
  438. <varname>$module</varname> は常に無視されます。
  439. 最後に、<varname>$params</varname> で指定した任意の値が
  440. リクエストオブジェクトに追加されます。
  441. コントローラやモジュールは不要だがパラメータは渡したいという場合は、
  442. コントローラやモジュールに null を指定します。
  443. </para>
  444. </listitem>
  445. </itemizedlist>
  446. </sect2>
  447. <sect2 id="zend.controller.migration.fromzerotwo">
  448. <title>0.2.0 以前のバージョンから 0.6.0 への移行</title>
  449. <para>
  450. MVC コンポーネントの基本的な部分は変わっていません。
  451. 次のいずれの方法も使用可能です。
  452. </para>
  453. <programlisting language="php"><![CDATA[
  454. Zend_Controller_Front::run('/path/to/controllers');
  455. ]]></programlisting>
  456. <programlisting language="php"><![CDATA[
  457. /* -- ルータを作成します -- */
  458. $router = new Zend_Controller_RewriteRouter();
  459. $router->addRoute('user',
  460. 'user/:username',
  461. array('controller' => 'user', 'action' => 'info')
  462. );
  463. /* -- ルータをコントローラに設定します -- */
  464. $ctrl = Zend_Controller_Front::getInstance();
  465. $ctrl->setRouter($router);
  466. /* -- コントローラのディレクトリを設定し、ディスパッチします -- */
  467. $ctrl->setControllerDirectory('/path/to/controllers');
  468. $ctrl->dispatch();
  469. ]]></programlisting>
  470. <para>
  471. レスポンスオブジェクトを使用して、コンテンツとヘッダを取得することを推奨します。
  472. これにより、アプリケーション内で
  473. より柔軟な出力書式の切り替え (たとえば XHTML ではなく
  474. JSON や XML を使用するなど) ができるようになります。
  475. デフォルトでは、<code>dispatch()</code> はレスポンスのレンダリングを行い、
  476. ヘッダとレンダリングされた内容の両方を送信します。
  477. フロントコントローラから <code>returnResponse()</code>
  478. を使用してレスポンスを返し、レスポンスのレンダリングを独自に行うこともできます。
  479. 将来のバージョンのフロントコントローラでは、
  480. レスポンスオブジェクトに出力バッファリングを使用する予定です。
  481. </para>
  482. <para>
  483. これまでの API に加え、多くの機能が追加されています。
  484. 追加された機能についてはドキュメントを参照ください。
  485. </para>
  486. <para>
  487. 最大の変更点は、多くのコンポーネントで
  488. サブクラス化による拡張が可能になったことです。以下にポイントを整理します。
  489. </para>
  490. <itemizedlist>
  491. <listitem>
  492. <para>
  493. <classname>Zend_Controller_Front::dispatch()</classname>
  494. は、デフォルトでレスポンスオブジェクトの例外をトラップします。
  495. 例外の内容はレンダリングしません。これにより、
  496. システムについての機密情報がレンダリングされてしまうことを防ぎます。
  497. この挙動を変更するにはいくつかの方法があります。
  498. </para>
  499. <itemizedlist>
  500. <listitem>
  501. <para>
  502. フロントコントローラで <code>throwExceptions()</code>
  503. を設定します。
  504. </para>
  505. <programlisting language="php"><![CDATA[
  506. $front->throwExceptions(true);
  507. ]]></programlisting>
  508. </listitem>
  509. <listitem>
  510. <para>
  511. レスポンスオブジェクトで <code>renderExceptions()</code>
  512. を設定します。
  513. </para>
  514. <programlisting language="php"><![CDATA[
  515. $response->renderExceptions(true);
  516. $front->setResponse($response);
  517. $front->dispatch();
  518. // あるいは
  519. $front->returnResponse(true);
  520. $response = $front->dispatch();
  521. $response->renderExceptions(true);
  522. echo $response;
  523. ]]></programlisting>
  524. </listitem>
  525. </itemizedlist>
  526. </listitem>
  527. <listitem><para>
  528. <classname>Zend_Controller_Dispatcher_Interface::dispatch()</classname>
  529. は、ディスパッチャトークンではなく
  530. <xref linkend="zend.controller.request" />
  531. オブジェクトを使用するようになりました。
  532. </para></listitem>
  533. <listitem><para>
  534. <classname>Zend_Controller_Router_Interface::route()</classname>
  535. は、ディスパッチャトークンではなく
  536. <xref linkend="zend.controller.request" />
  537. オブジェクトを使用するようになりました。
  538. </para></listitem>
  539. <listitem>
  540. <para><classname>Zend_Controller_Action</classname> の変更点は以下のようになります。</para>
  541. <itemizedlist>
  542. <listitem><para>
  543. コンストラクタが受け付ける引数は
  544. <classname>Zend_Controller_Request_Abstract $request</classname>、
  545. <classname>Zend_Controller_Response_Abstract $response</classname>
  546. および <code>array $params (optional)</code> の三つになりました。
  547. <classname>Zend_Controller_Action::__construct()</classname>
  548. は、これらを使用してリクエストやレスポンス、
  549. そしてオブジェクトの invokeArgs プロパティを指定します。
  550. コンストラクタをオーバーライドすることで、
  551. この挙動をお望みのように変更することができます。
  552. さらによいことに、<code>init()</code>
  553. メソッドを使用してインスタンスの設定を自由に行うことができます。
  554. このメソッドは、コンストラクタでの処理の最後にコールされます。
  555. </para></listitem>
  556. <listitem><para>
  557. <code>run()</code> は final メソッドではなくなりました。
  558. しかし、このメソッドはもはやフロントコントローラでは使用されません。
  559. これは、クラスをページコントローラとして使用する場合にのみ使用します。
  560. オプションの引数
  561. <classname>Zend_Controller_Request_Abstract $request</classname>
  562. および <classname>Zend_Controller_Response_Abstract $response</classname>
  563. を受け取ります。
  564. </para></listitem>
  565. <listitem><para>
  566. <code>indexAction()</code> を定義する必要はなくなりました。
  567. しかし、デフォルトのアクションとして定義しておくことを推奨します。
  568. これにより、RewriteRouter とアクションコントローラで
  569. デフォルトのアクションメソッドを別々に指定できるようになります。
  570. </para></listitem>
  571. <listitem><para>
  572. <code>__call()</code> をオーバーライドして、
  573. 未定義のアクションが自動的に処理されるようにする必要があります。
  574. </para></listitem>
  575. <listitem><para>
  576. <code>_redirect()</code> にはオプションで二番目、三番目の引数が追加されました。
  577. 二番目の引数はリダイレクト時に返す HTTP コードです。
  578. 三番目の引数 <varname>$prependBase</varname>
  579. を使用すると、リクエストオブジェクトに登録したベース URL
  580. を URL の前に連結することを指示できます。
  581. </para></listitem>
  582. <listitem>
  583. <para>
  584. プロパティ <code>_action</code> は設定されなくなりました。
  585. このプロパティの内容は <classname>Zend_Controller_Dispatcher_Token</classname>
  586. でしたが、これは現在のバージョンにはもう存在しません。
  587. トークンの唯一の目的は、要求されたコントローラやアクション、
  588. URL パラメータについての情報を提供することでした。
  589. これらは現在はリクエストオブジェクトから次のようにして取得できるようになっています。
  590. </para>
  591. <programlisting language="php"><![CDATA[
  592. // 要求されたコントローラ名を取得します。
  593. // その際には $this->_action->getControllerName() を使用します。
  594. // 以下の例では getRequest() を使用していますが、直接 $_request プロパティに
  595. // アクセスしてもかまいません。ただ getRequest() を使用することを推奨します。
  596. // とういのは、親クラスがこのメソッドをオーバーライドして挙動を変更しているかもしれないからです。
  597. $controller = $this->getRequest()->getControllerName();
  598. // 要求されたアクション名を取得します。
  599. // その際には $this->_action->getActionName() を使用します。
  600. $action = $this->getRequest()->getActionName();
  601. // リクエストパラメータを取得します。
  602. // これは変わっていません。_getParams() メソッドおよび _getParam() メソッドは
  603. // 現在は単なるリクエストオブジェクトへのプロキシです。
  604. $params = $this->_getParams();
  605. // パラメータ 'foo' を取得します。見つからなかった場合はデフォルト値 'default' を設定します
  606. $foo = $this->_getParam('foo', 'default');
  607. ]]></programlisting>
  608. </listitem>
  609. <listitem>
  610. <para>
  611. <code>noRouteAction()</code> は削除されました。
  612. 存在しないアクションメソッドを扱うには、
  613. <code>__call()</code> を使用してデフォルトのアクションに誘導します。
  614. </para>
  615. <programlisting language="php"><![CDATA[
  616. public function __call($method, $args)
  617. {
  618. // 存在しない 'Action' メソッドが要求された場合に、
  619. // それをデフォルトのアクションに渡します。
  620. if ('Action' == substr($method, -6)) {
  621. return $this->defaultAction();
  622. }
  623. throw new Zend_Controller_Exception('無効なメソッド呼び出しです');
  624. }
  625. ]]></programlisting>
  626. </listitem>
  627. </itemizedlist>
  628. </listitem>
  629. <listitem><para>
  630. <classname>Zend_Controller_RewriteRouter::setRewriteBase()</classname>
  631. は削除されました。かわりに
  632. <classname>Zend_Controller_Front::setBaseUrl()</classname> を使用してください
  633. (あるいは、リクエストクラスを使用している場合は
  634. <classname>Zend_Controller_Request_Http::setBaseUrl()</classname> を使用します)。
  635. </para></listitem>
  636. <listitem><para>
  637. <classname>Zend_Controller_Plugin_Interface</classname> は
  638. <classname>Zend_Controller_Plugin_Abstract</classname> に置き換えられました。
  639. すべてのメソッドは、ディスパッチャトークンではなく
  640. <xref linkend="zend.controller.request" />
  641. をやり取りするようになりました。
  642. </para></listitem>
  643. </itemizedlist>
  644. </sect2>
  645. </sect1>
  646. <!--
  647. vim:se ts=4 sw=4 et:
  648. -->