2
0

Zend_Controller-Request.xml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15719 -->
  4. <sect1 id="zend.controller.request">
  5. <title>リクエストオブジェクト</title>
  6. <sect2 id="zend.controller.request.introduction">
  7. <title>導入</title>
  8. <para>
  9. リクエストオブジェクトとは <classname>Zend_Controller_Front</classname> とルータ、
  10. ディスパッチャそしてコントローラクラスの間でやり取りされる単純なバリューオブジェクトです。
  11. これはコントローラ、アクションそして環境 (HTTP、CLI、PHP-GTK など)
  12. に応じたその他のパラメータの内容をまとめたものです。
  13. </para>
  14. <itemizedlist>
  15. <listitem><para>
  16. モジュール名にアクセスするには
  17. <code>getModuleName()</code> および
  18. <code>setModuleName()</code> を使用します。
  19. </para></listitem>
  20. <listitem><para>
  21. コントローラ名にアクセスするには
  22. <code>getControllerName()</code> および
  23. <code>setControllerName()</code> を使用します。
  24. </para></listitem>
  25. <listitem><para>
  26. コントローラ内でコールするアクションの名前にアクセスするには
  27. <code>getActionName()</code> および
  28. <code>setActionName()</code> を使用します。
  29. </para></listitem>
  30. <listitem><para>
  31. アクションからアクセスできるパラメータは
  32. キー/値 の組み合わせの連想配列となります。これらを取得するには
  33. <code>getParams()</code> を、そして設定するには
  34. <code>setParams()</code> を使用します。各パラメータを個別に扱うには
  35. <code>getParam()</code> および <code>setParam()</code> を使用します。
  36. </para></listitem>
  37. </itemizedlist>
  38. <para>
  39. リクエストの型によっては、その他のメソッドが使用できることもあります。
  40. たとえば、デフォルトのリクエストで使用する
  41. <classname>Zend_Controller_Request_Http</classname> の場合は、
  42. リクエストされた URI やパス情報、
  43. <varname>$_GET</varname> パラメータや <varname>$_POST</varname>
  44. パラメータを取得するメソッドが使用可能となります。
  45. </para>
  46. <para>
  47. リクエストオブジェクトはフロントコントローラに渡されます。
  48. もしリクエストオブジェクトがなかった場合は、
  49. ディスパッチ処理の最初 (ルーティングが発生する前)
  50. にインスタンスが作成されます。これは、
  51. ディスパッチチェインのすべてのオブジェクトに渡されていきます。
  52. </para>
  53. <para>
  54. さらに、リクエストオブジェクトはテストの際にも有用です。
  55. 開発者がリクエストを作成し、コントローラやアクション、
  56. パラメータや URI などを指定してそれをフロントコントローラに渡すことで、
  57. アプリケーションの流れをテストすることができます。
  58. <link linkend="zend.controller.response">レスポンスオブジェクト</link>
  59. と組み合わせて使用すると、
  60. MVC アプリケーションの精密で正確な単体テストが可能となります。
  61. </para>
  62. </sect2>
  63. <sect2 id="zend.controller.request.http">
  64. <title>HTTP リクエスト</title>
  65. <sect3 id="zend.controller.request.http.dataacess">
  66. <title>リクエストデータへのアクセス</title>
  67. <para>
  68. <classname>Zend_Controller_Request_Http</classname> は、関連する値へのアクセスをカプセル化します。
  69. たとえばコントローラやアクションルータの変数のキー名や値、
  70. URI からパースした追加のパラメータの値などにアクセスできます。
  71. <classname>Zend_Controller_Request_Http</classname> のプロキシとして動作することで、
  72. スーパーグローバルの値にパブリックメンバとしてアクセスしたり、
  73. 現在のベース URL やリクエスト URI を管理することもできます。
  74. スーパーグローバルの値はリクエストオブジェクトに設定することはできません。
  75. そのかわりに setParam/getParam メソッドを使用して、
  76. パラメータを設定あるいは取得します。
  77. </para>
  78. <note>
  79. <title>スーバーグローバルデータ</title>
  80. <para>
  81. <classname>Zend_Controller_Request_Http</classname> のパブリックプロパティを使用して
  82. スーパーグローバルデータにアクセスする際に注意すべき点は、
  83. プロパティ名 (スーバーグローバル配列のキー)
  84. は以下の優先順位でマッチするということです。
  85. 1. GET, 2. POST, 3. COOKIE, 4. SERVER, 5. ENV.
  86. </para>
  87. </note>
  88. <para>
  89. 特定のスーパーグローバルにアクセスするには、
  90. パブリックメソッドを使用する方法もあります。たとえば、
  91. <varname>$_POST['user']</varname> の値を取得するには、リクエストオブジェクト上で
  92. <code>getPost('user')</code> をコールします。同様に、
  93. <varname>$_GET</varname> 要素の場合は <code>getQuery()</code>、
  94. リクエストヘッダの場合は <code>getHeader()</code>
  95. を使用します。
  96. </para>
  97. <note>
  98. <title>GET および POST データ</title>
  99. <para>
  100. リクエストオブジェクトのデータを扱う際には注意しましょう。
  101. これらのデータは、一切フィルタリングを行っていません。
  102. ルータやディスパッチャのほうで適切な検証とフィルタリングを行うので、
  103. リクエストオブジェクト内のデータはそのままにしておきましょう。
  104. </para>
  105. </note>
  106. <note>
  107. <title>生の POST データの取得</title>
  108. <para>
  109. 1.5.0 以降では、生の投稿データを
  110. <code>getRawBody()</code> メソッドで取得することができます。
  111. このメソッドは、データが送信されていない場合は false を返します。
  112. 送信されている場合は、投稿内容の本文全体を返します。
  113. </para>
  114. <para>
  115. これは、RESTful な MVC
  116. アプリケーションを開発するにあたって非常に有用です。
  117. </para>
  118. </note>
  119. <para>
  120. ユーザパラメータをリクエストオブジェクトに設定するには
  121. <code>setParam()</code> を、後でそれを取得するには
  122. <code>getParam()</code> を使用します。
  123. ルータは、リクエスト URI にマッチしたパラメータを
  124. リクエストオブジェクトに設定する際にこの機能を使用します。
  125. </para>
  126. <note>
  127. <title>getParam() でのユーザパラメータ以外の取得</title>
  128. <para>
  129. <code>getParam()</code> は、実際にはユーザパラメータ以外のところからも情報を取得しています。
  130. 優先順位の高い順に並べると、まず最初は <code>setParam()</code>
  131. で設定したパラメータ、それから <code>GET</code> パラメータ、
  132. <code>POST</code> パラメータの順になります。
  133. このメソッドを使用する際には、この点に注意しましょう。
  134. </para>
  135. <para>
  136. <code>setParam()</code> で設定したパラメータからだけ取得したい場合は、
  137. <code>getUserParam()</code> を使用します。
  138. </para>
  139. <para>
  140. さらに、1.5.0 以降では
  141. どのパラメータから検索するかを制限することができます。
  142. <code>setParamSources()</code> に空の配列あるいは
  143. 値 '_GET' や '_POST' を含む配列を指定して使用します
  144. (デフォルトでは両方が指定されています)。'_GET'
  145. からのみに制限したい場合は
  146. <code>setParamSources(array('_GET'))</code> とします。
  147. </para>
  148. </note>
  149. <note>
  150. <title>Apache のおかしな挙動</title>
  151. <para>
  152. Apache の 404 ハンドラを使用して
  153. リクエストをフロントコントローラに渡したり、
  154. PT フラグを rewrite ルールで使用したりする場合は、
  155. 必要な URI 情報が含まれるのが
  156. <varname>$_SERVER['REQUEST_URI']</varname>
  157. ではなく <varname>$_SERVER['REDIRECT_URL']</varname>
  158. であることに注意しましょう。
  159. この設定を使用して無効なルーティングを取得したい場合は、
  160. デフォルトの Http クラスではなく
  161. <classname>Zend_Controller_Request_Apache404</classname>
  162. クラスを使用してリクエストオブジェクトを作成しなければなりません。
  163. </para>
  164. <programlisting language="php"><![CDATA[
  165. $request = new Zend_Controller_Request_Apache404();
  166. $front->setRequest($request);
  167. ]]></programlisting>
  168. <para>
  169. このクラスは
  170. <classname>Zend_Controller_Request_Http</classname>
  171. クラスを継承したもので、リクエスト URI
  172. を自動で検出できるように変更しています。
  173. これは、単純にもとのクラスと差し替えて使用できます。
  174. </para>
  175. </note>
  176. </sect3>
  177. <sect3 id="zend.controller.request.http.baseurl">
  178. <title>ベース URL およびサブディレクトリ</title>
  179. <para>
  180. <classname>Zend_Controller_Request_Http</classname> は、
  181. サブディレクトリで <classname>Zend_Controller_Router_Rewrite</classname> を使用することができます。
  182. <classname>Zend_Controller_Request_Http</classname> は自動的にベース URL を検出し、
  183. それを適切に設定します。
  184. </para>
  185. <para>
  186. たとえば、<code>index.php</code> をウェブサーバのサブディレクトリ
  187. <code>/projects/myapp/index.php</code> においた場合は、ベース URL
  188. (rewrite base) は <code>/projects/myapp</code> にしなければなりません。
  189. マッチするルートを見つける前に、この文字列がパスの先頭から取り除かれます。
  190. これにより、すべてのルートに余計な文字を追加する必要がなくなります。
  191. ルート <code>'user/:username'</code> は、
  192. <code>http://localhost/projects/myapp/user/martel</code> および
  193. <code>http://example.com/user/martel</code> の両方にマッチするようになります。
  194. </para>
  195. <note>
  196. <title>URL の検出は大文字小文字を区別します</title>
  197. <para>
  198. 自動的なベース URL の検出処理は大文字小文字を区別します。そのため、
  199. URL とファイルシステムのサブディレクトリ名が確実に一致する必要があります
  200. (たとえ Windows マシンであっても同様です)。大文字小文字が一致しなかった場合は、
  201. 例外が発生します。
  202. </para>
  203. </note>
  204. <para>
  205. ベース URL の検出に失敗する場合は、
  206. <classname>Zend_Controller_Request_Http</classname> クラス、あるいは
  207. <classname>Zend_Controller_Front</classname> クラスの
  208. <code>setBaseUrl()</code> メソッドを使用して
  209. ベースパスを上書き指定することができます。
  210. 一番簡単な方法は <classname>Zend_Controller_Front</classname> で設定することです。
  211. この設定はリクエストオブジェクトに引き継がれます。
  212. 独自のベース URL を設定する例を示します。
  213. </para>
  214. <programlisting language="php"><![CDATA[
  215. /**
  216. * Zend_Controller_Front で独自のベース URL を指定することによるリクエストのディスパッチ
  217. */
  218. $router = new Zend_Controller_Router_Rewrite();
  219. $controller = Zend_Controller_Front::getInstance();
  220. $controller->setControllerDirectory('./application/controllers')
  221. ->setRouter($router)
  222. ->setBaseUrl('/projects/myapp'); // ベース URL を指定します!
  223. $response = $controller->dispatch();
  224. ]]></programlisting>
  225. </sect3>
  226. <sect3 id="zend.controller.request.http.method">
  227. <title>リクエストメソッドの判定</title>
  228. <para>
  229. <code>getMethod()</code> では、
  230. 現在のリソースへのリクエストの際に使用した
  231. HTTP メソッドを判定することができます。
  232. さらに、指定した型のリクエストであったかどうかを判定するための
  233. メソッドも用意されています。
  234. </para>
  235. <itemizedlist>
  236. <listitem><para><code>isGet()</code></para></listitem>
  237. <listitem><para><code>isPost()</code></para></listitem>
  238. <listitem><para><code>isPut()</code></para></listitem>
  239. <listitem><para><code>isDelete()</code></para></listitem>
  240. <listitem><para><code>isHead()</code></para></listitem>
  241. <listitem><para><code>isOptions()</code></para></listitem>
  242. </itemizedlist>
  243. <para>
  244. これらの主な使用法は、RESTfult な
  245. MVC アーキテクチャを作成することです。
  246. </para>
  247. </sect3>
  248. <sect3 id="zend.controller.request.http.ajax">
  249. <title>AJAX リクエストの検出</title>
  250. <para>
  251. <classname>Zend_Controller_Request_Http</classname> には、
  252. AJAX リクエストを検出するための基本的なメソッド
  253. <code>isXmlHttpRequest()</code> が用意されています。
  254. このメソッドは、HTTP リクエストヘッダ
  255. <code>X-Requested-With</code> に
  256. 'XMLHttpRequest' という値が設定されているかどうかを調べ、
  257. 設定されている場合に true を返します。
  258. </para>
  259. <para>
  260. 現時点では、次の JS ライブラリがデフォルトでこのヘッダを渡すようです。
  261. </para>
  262. <itemizedlist>
  263. <listitem><para>Prototype/Scriptaculous (その他
  264. Prototype 系のライブラリ)</para></listitem>
  265. <listitem><para>Yahoo! UI Library</para></listitem>
  266. <listitem><para>jQuery</para></listitem>
  267. <listitem><para>MochiKit</para></listitem>
  268. </itemizedlist>
  269. <para>
  270. 大半の AJAX ライブラリは、独自の HTTP リクエストヘッダを送信することができます。
  271. ご利用のライブラリがこのヘッダを送信していない場合は、
  272. 自分でこのヘッダを追加することで
  273. <code>isXmlHttpRequest()</code> メソッドの動作を期待通りにすることができます。
  274. </para>
  275. </sect3>
  276. </sect2>
  277. <sect2 id="zend.controller.request.subclassing">
  278. <title>リクエストオブジェクトのサブクラスの作成</title>
  279. <para>
  280. すべてのリクエストオブジェクトクラスは、抽象クラス
  281. <classname>Zend_Controller_Request_Abstract</classname> を継承しています。
  282. このクラスでは、次のようなメソッドを定義しています。
  283. </para>
  284. <programlisting language="php"><![CDATA[
  285. abstract class Zend_Controller_Request_Abstract
  286. {
  287. /**
  288. * @return string
  289. */
  290. public function getControllerName();
  291. /**
  292. * @param string $value
  293. * @return self
  294. */
  295. public function setControllerName($value);
  296. /**
  297. * @return string
  298. */
  299. public function getActionName();
  300. /**
  301. * @param string $value
  302. * @return self
  303. */
  304. public function setActionName($value);
  305. /**
  306. * @return string
  307. */
  308. public function getControllerKey();
  309. /**
  310. * @param string $key
  311. * @return self
  312. */
  313. public function setControllerKey($key);
  314. /**
  315. * @return string
  316. */
  317. public function getActionKey();
  318. /**
  319. * @param string $key
  320. * @return self
  321. */
  322. public function setActionKey($key);
  323. /**
  324. * @param string $key
  325. * @return mixed
  326. */
  327. public function getParam($key);
  328. /**
  329. * @param string $key
  330. * @param mixed $value
  331. * @return self
  332. */
  333. public function setParam($key, $value);
  334. /**
  335. * @return array
  336. */
  337. public function getParams();
  338. /**
  339. * @param array $array
  340. * @return self
  341. */
  342. public function setParams(array $array);
  343. /**
  344. * @param boolean $flag
  345. * @return self
  346. */
  347. public function setDispatched($flag = true);
  348. /**
  349. * @return boolean
  350. */
  351. public function isDispatched();
  352. }
  353. ]]></programlisting>
  354. <para>
  355. リクエストオブジェクトは、リクエスト環境のコンテナとなります。
  356. コントローラチェインが知っておくべきことは、
  357. コントローラやアクション、オプションパラメータ、ディスパッチ状況
  358. を取得したり設定したりする方法だけです。
  359. デフォルトでは、リクエストオブジェクトが
  360. コントローラおよびアクションを決定する際には
  361. キー controller あるいは action を使用します。
  362. </para>
  363. <para>
  364. このクラスかその派生クラスのいずれかを継承したクラスを作成することで、
  365. 上で説明した作業を独自のものに変更したクラスを作成することができます。
  366. 例としては、たとえば <link linkend="zend.controller.request.http">HTTP
  367. 環境用</link> のクラスや CLI 環境用、PHP-GTK 環境用のクラスがあります。
  368. </para>
  369. </sect2>
  370. </sect1>
  371. <!--
  372. vim:se ts=4 sw=4 et:
  373. -->