Zend_Http_Response.xml 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17175 -->
  4. <sect1 id="zend.http.response">
  5. <title>Zend_Http_Response</title>
  6. <sect2 id="zend.http.response.introduction">
  7. <title>導入</title>
  8. <para>
  9. <classname>Zend_Http_Response</classname> は、<acronym>HTTP</acronym> レスポンスに簡単にアクセスできるようにします。
  10. また、<acronym>HTTP</acronym> レスポンスメッセージをパースするための静的メソッド群も提供します。
  11. 通常は、<classname>Zend_Http_Response</classname> は <classname>Zend_Http_Client</classname>
  12. リクエストの返す結果として使用します。
  13. </para>
  14. <para>
  15. ほとんどの場合は、Zend_Http_Response オブジェクトのインスタンスを作成するには
  16. factory() メソッドを使用します。これは、<acronym>HTTP</acronym>
  17. レスポンスメッセージを含む文字列を受け取って新しい
  18. Zend_Http_Response オブジェクトを返します。
  19. <example id="zend.http.response.introduction.example-1">
  20. <title>ファクトリメソッドを使用した Zend_Http_Response オブジェクトの作成</title>
  21. <programlisting language="php"><![CDATA[
  22. $str = '';
  23. $sock = fsockopen('www.example.com', 80);
  24. $req = "GET / HTTP/1.1\r\n" .
  25. "Host: www.example.com\r\n" .
  26. "Connection: close\r\n" .
  27. "\r\n";
  28. fwrite($sock, $req);
  29. while ($buff = fread($sock, 1024))
  30. $str .= $sock;
  31. $response = Zend_Http_Response::factory($str);
  32. ]]></programlisting>
  33. </example>
  34. </para>
  35. <para>
  36. コンストラクタを使用して新しいオブジェクトを作成することもできます。
  37. その際には、レスポンスの全パラメータを指定します。
  38. </para>
  39. <para>
  40. <code>
  41. public function __construct($code, $headers, $body = null, $version = '1.1', $message = null)
  42. </code>
  43. </para>
  44. <itemizedlist>
  45. <listitem>
  46. <para>
  47. <varname>$code</varname>: <acronym>HTTP</acronym> レスポンスコード (たとえば 200 や 404 など)。
  48. </para>
  49. </listitem>
  50. <listitem>
  51. <para>
  52. <varname>$headers</varname>: <acronym>HTTP</acronym> レスポンスヘッダの連想配列 (たとえば 'Host' => 'example.com' など)。
  53. </para>
  54. </listitem>
  55. <listitem>
  56. <para>
  57. <varname>$body</varname>: レスポンス本文の文字列。
  58. </para>
  59. </listitem>
  60. <listitem>
  61. <para>
  62. <varname>$version</varname>: <acronym>HTTP</acronym> レスポンスのバージョン (通常は 1.0 あるいは 1.1)。
  63. </para>
  64. </listitem>
  65. <listitem>
  66. <para>
  67. <varname>$message</varname>: <acronym>HTTP</acronym> レスポンスメッセージ (たとえば 'OK' や 'Internal Server Error' など)。
  68. 指定しなかった場合は、レスポンスコードに応じたメッセージが設定されます。
  69. </para>
  70. </listitem>
  71. </itemizedlist>
  72. </sect2>
  73. <sect2 id="zend.http.response.testers">
  74. <title>真偽チェック用のメソッド</title>
  75. <para>
  76. <classname>Zend_Http_Response</classname> のインスタンスを取得すると、
  77. レスポンスの種類を調べるためのメソッドが使用できるようになります。
  78. これらのメソッドは、すべて true あるいは false を返します。
  79. <itemizedlist>
  80. <listitem>
  81. <para>
  82. <code>Boolean isSuccessful()</code>: リクエストが成功したかどうかを調べます。
  83. <acronym>HTTP</acronym> レスポンスコードが 1xx か 2xx であった場合に TRUE を返します。
  84. </para>
  85. </listitem>
  86. <listitem>
  87. <para>
  88. <code>Boolean isError()</code>: レスポンスコードがエラーを意味しているかどうかを調べます。
  89. <acronym>HTTP</acronym> レスポンスコードが 4xx (クライアントのエラー) あるいは
  90. 5xx (サーバのエラー) であった場合に TRUE を返します。
  91. </para>
  92. </listitem>
  93. <listitem>
  94. <para>
  95. <code>Boolean isRedirect()</code>: レスポンスがリダイレクトされているかどうかを調べます。
  96. <acronym>HTTP</acronym> レスポンスコードが 3xx であった場合に TRUE を返します。
  97. </para>
  98. </listitem>
  99. </itemizedlist>
  100. <example id="zend.http.response.testers.example-1">
  101. <title>isError() メソッドの使用によるレスポンスの検証</title>
  102. <programlisting language="php"><![CDATA[
  103. if ($response->isError()) {
  104. echo "データ転送エラー。\n"
  105. echo "サーバからの応答: " . $response->getStatus() .
  106. " " . $response->getMessage() . "\n";
  107. }
  108. // .. ここでレスポンスを処理します...
  109. ]]></programlisting>
  110. </example>
  111. </para>
  112. </sect2>
  113. <sect2 id="zend.http.response.acessors">
  114. <title>アクセス用メソッド群</title>
  115. <para>
  116. レスポンスオブジェクトの本来の目的は、レスポンスパラメータに簡単にアクセスすることです。
  117. <itemizedlist>
  118. <listitem>
  119. <para>
  120. <code>int getStatus()</code>: <acronym>HTTP</acronym> レスポンスステータスコード
  121. (たとえば 200 や 504 など) を取得します。
  122. </para>
  123. </listitem>
  124. <listitem>
  125. <para>
  126. <code>string getMessage()</code>: <acronym>HTTP</acronym> レスポンスステータスのメッセージ
  127. (たとえば "Not Found" や "Authorization Required" など) を取得します。
  128. </para>
  129. </listitem>
  130. <listitem>
  131. <para>
  132. <code>string getBody()</code>: <acronym>HTTP</acronym> レスポンス本文をデコードしたものを取得します。
  133. </para>
  134. </listitem>
  135. <listitem>
  136. <para>
  137. <code>string getRawBody()</code>: そのままの状態の、おそらくエンコードされている
  138. <acronym>HTTP</acronym> レスポンス本文を取得します。たとえば GZIP などでエンコードされていたとしても、
  139. それはデコードされません。
  140. </para>
  141. </listitem>
  142. <listitem>
  143. <para>
  144. <code>array getHeaders()</code>: <acronym>HTTP</acronym> レスポンスヘッダを、連想配列形式
  145. (たとえば 'Content-type' => 'text/html' など) で取得します。
  146. </para>
  147. </listitem>
  148. <listitem>
  149. <para>
  150. <code>string|array getHeader($header)</code>: $header で指定した、
  151. 特定の <acronym>HTTP</acronym> レスポンスヘッダを取得します。
  152. </para>
  153. </listitem>
  154. <listitem>
  155. <para>
  156. <code>string getHeadersAsString($status_line = true, $br = "\n")</code>:
  157. ヘッダ全体を文字列として取得します。$status_line が true の場合 (デフォルト) は、
  158. 最初のステータス行 (たとえば "HTTP/1.1 200 OK" など) も返されます。
  159. 改行は $br パラメータで指定します (たとえば "&lt;br /&gt;" などにもできます)。
  160. </para>
  161. </listitem>
  162. <listitem>
  163. <para>
  164. <code>string asString($br = "\n")</code>: レスポンスメッセージ全体を文字列として取得します。
  165. 改行は $br パラメータで指定します (たとえば "&lt;br /&gt;" などにもできます)。
  166. マジックメソッド __toString()
  167. を使ってオブジェクトを文字列にキャストすることができます。
  168. これは asString() へのプロキシとなります。
  169. </para>
  170. </listitem>
  171. </itemizedlist>
  172. <example id="zend.http.response.acessors.example-1">
  173. <title>Zend_Http_Response へのアクセス用メソッドの使用</title>
  174. <programlisting language="php"><![CDATA[
  175. if ($response->getStatus() == 200) {
  176. echo "リクエストの結果は次のようになりました。<br />";
  177. echo $response->getBody();
  178. } else {
  179. echo "データの取得時にエラーが発生しました。<br />";
  180. echo $response->getStatus() . ": " . $response->getMessage();
  181. }
  182. ]]></programlisting>
  183. </example>
  184. <note>
  185. <title>常に返り値をチェックする</title>
  186. <para>
  187. レスポンスには同じヘッダを複数含めることができるので、
  188. getHeader() メソッドや getHeaders() メソッドの返す結果は
  189. 文字列の場合もあれば文字列の配列となる場合もあります。
  190. 返された値が文字列なのか配列なのかを常にチェックするようにしましょう。
  191. </para>
  192. </note>
  193. <example id="zend.http.response.acessors.example-2">
  194. <title>レスポンスヘッダへのアクセス</title>
  195. <programlisting language="php"><![CDATA[
  196. $ctype = $response->getHeader('Content-type');
  197. if (is_array($ctype)) $ctype = $ctype[0];
  198. $body = $response->getBody();
  199. if ($ctype == 'text/html' || $ctype == 'text/xml') {
  200. $body = htmlentities($body);
  201. }
  202. echo $body;
  203. ]]></programlisting>
  204. </example>
  205. </para>
  206. </sect2>
  207. <sect2 id="zend.http.response.static_parsers">
  208. <title>静的 HTTP レスポンスパーサ</title>
  209. <para>
  210. <classname>Zend_Http_Response</classname> クラスには、内部で使用するメソッドもいくつか含まれています。
  211. これは、<acronym>HTTP</acronym> レスポンスメッセージを処理したりパースしたりするためのものです。
  212. これらのメソッドは静的メソッドとして公開されています。
  213. つまり外部からでも使用できるということです。特にインスタンスを作成しなくても、
  214. レスポンスの一部を抽出したりなどといった目的で使用可能です。
  215. <itemizedlist>
  216. <listitem>
  217. <para>
  218. <code>int Zend_Http_Response::extractCode($response_str)</code>:
  219. <acronym>HTTP</acronym> レスポンスコード (たとえば 200 や 404 など)
  220. を $response_str から抽出し、それを返します。
  221. </para>
  222. </listitem>
  223. <listitem>
  224. <para>
  225. <code>string Zend_Http_Response::extractMessage($response_str)</code>:
  226. <acronym>HTTP</acronym> レスポンスメッセージ (たとえば "OK" や "File Not Found" など)
  227. を $response_str から抽出し、それを返します。
  228. </para>
  229. </listitem>
  230. <listitem>
  231. <para>
  232. <code>string Zend_Http_Response::extractVersion($response_str)</code>:
  233. <acronym>HTTP</acronym> バージョン (たとえば 1.1 や 1.0 など)
  234. を $response_str から抽出し、それを返します。
  235. </para>
  236. </listitem>
  237. <listitem>
  238. <para>
  239. <code>array Zend_Http_Response::extractHeaders($response_str)</code>:
  240. <acronym>HTTP</acronym> レスポンスヘッダを $response_str から抽出し、それを配列で返します。
  241. </para>
  242. </listitem>
  243. <listitem>
  244. <para>
  245. <code>string Zend_Http_Response::extractBody($response_str)</code>:
  246. <acronym>HTTP</acronym> レスポンス本文を $response_str から抽出し、それを返します。
  247. </para>
  248. </listitem>
  249. <listitem>
  250. <para>
  251. <code>string Zend_Http_Response::responseCodeAsText($code = null, $http11 = true)</code>:
  252. レスポンスコード $code に対応する、標準的な <acronym>HTTP</acronym> レスポンスメッセージを取得します。
  253. たとえば $code が 500 の場合は "Internal Server Error" を返します。
  254. $http11 が true の場合 (デフォルト) は <acronym>HTTP</acronym>/1.1 のメッセージを、
  255. そうでない場合は <acronym>HTTP</acronym>/1.0 のメッセージを返します。
  256. $code を省略した場合は、このメソッドは、すべての既知の <acronym>HTTP</acronym>
  257. レスポンスコードを連想配列 (code => message) で返します。
  258. </para>
  259. </listitem>
  260. </itemizedlist>
  261. </para>
  262. <para>
  263. パーサメソッド以外にも、このクラスには
  264. 一般的な <acronym>HTTP</acronym> レスポンスエンコーディングに対応したデコーダが含まれています。
  265. <itemizedlist>
  266. <listitem>
  267. <para>
  268. <code>string Zend_Http_Response::decodeChunkedBody($body)</code>:
  269. "Content-Transfer-Encoding: Chunked" の本文をデコードします。
  270. </para>
  271. </listitem>
  272. <listitem>
  273. <para>
  274. <code>string Zend_Http_Response::decodeGzip($body)</code>:
  275. "Content-Encoding: gzip" の本文をデコードします。
  276. </para>
  277. </listitem>
  278. <listitem>
  279. <para>
  280. <code>string Zend_Http_Response::decodeDeflate($body)</code>:
  281. "Content-Encoding: deflate" の本文をデコードします。
  282. </para>
  283. </listitem>
  284. </itemizedlist>
  285. </para>
  286. </sect2>
  287. </sect1>
  288. <!--
  289. vim:se ts=4 sw=4 et:
  290. -->