Zend_Http_Client.xml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.http.client">
  5. <title>導入</title>
  6. <para>
  7. Zend_Http_Client は、Hyper-Text Transfer Protocol (HTTP)
  8. リクエストを簡単に扱うためのインターフェイスを提供します。
  9. Zend_Http_Client は、HTTP クライアントとしての最低限の機能をサポートしているだけでなく、
  10. HTTP 認証やファイルのアップロードといった高度な機能もサポートしています。
  11. リクエストに成功すると (失敗しても) Zend_Http_Response
  12. オブジェクトを返します。これを使用すると、レスポンスのヘッダや本文にアクセスできます
  13. (<xref linkend="zend.http.response" /> を参照ください)。
  14. </para>
  15. <sect2 id="zend.http.client.usage">
  16. <title>Zend_Http_Client の使用法</title>
  17. <para>
  18. クラスのコンストラクタには、オプションの引数として URL を指定することができます
  19. (文字列か Zend_Uri_Http オブジェクトのどちらでも可能です)。
  20. また、オプションで設定パラメータの配列を指定することもできます。
  21. どちらも省略することが可能で、その場合は後から
  22. setUri() メソッドや setConfig() メソッドで指定します。
  23. <example id="zend.http.client.introduction.example-1">
  24. <title>Zend_Http_Client のインスタンスの作成</title>
  25. <programlisting role="php"><![CDATA[
  26. $client = new Zend_Http_Client('http://example.org', array(
  27. 'maxredirects' => 0,
  28. 'timeout' => 30));
  29. // これは、上とまったく同じことです
  30. $client = new Zend_Http_Client();
  31. $client->setUri('http://example.org');
  32. $client->setConfig(array(
  33. 'maxredirects' => 0,
  34. 'timeout' => 30));
  35. ]]>
  36. </programlisting>
  37. </example>
  38. <note>
  39. <para>Zend_Http_Client は Zend_Uri_Http を用いて URL を検証します。
  40. つまり、URL 中にあるパイプ記号 ('|') やキャレット記号 ('^')
  41. などの特殊文字はデフォルトでは許可されないということです。
  42. これを変更するには、Zend_Uri のオプション 'allow_unwise' を
  43. 'true' に設定します。詳細は <xref linkend="zend.uri.validation.allowunwise" />
  44. を参照ください。</para>
  45. </note>
  46. </para>
  47. </sect2>
  48. <sect2 id="zend.http.client.configuration">
  49. <title>設定パラメータ</title>
  50. <para>
  51. コンストラクタおよび setConfig() メソッドでは
  52. 設定パラメータの連想配列を受け取ります。
  53. これらのパラメータは、設定してもしなくてもかまいません。
  54. すべてのパラメータにはデフォルト値があります。
  55. <table id="zend.http.client.configuration.table">
  56. <title>Zend_Http_Client の設定パラメータ</title>
  57. <tgroup cols="4">
  58. <thead>
  59. <row>
  60. <entry>パラメータ</entry>
  61. <entry>説明</entry>
  62. <entry>期待する値</entry>
  63. <entry>デフォルト値</entry>
  64. </row>
  65. </thead>
  66. <tbody>
  67. <row>
  68. <entry>maxredirects</entry>
  69. <entry>リダイレクトをたどる最大数 (0 = たどらない)</entry>
  70. <entry>integer</entry>
  71. <entry>5</entry>
  72. </row>
  73. <row>
  74. <entry>strict</entry>
  75. <entry>ヘッダ名の検証を行うかどうか。false に設定すると、検証関数をスキップします。通常はこれを変更してはいけません。</entry>
  76. <entry>boolean</entry>
  77. <entry>true</entry>
  78. </row>
  79. <row>
  80. <entry>strictredirects</entry>
  81. <entry>リダイレクトの際に RFC に厳密に従うかどうか (<xref linkend="zend.http.client.redirections" /> を参照ください)</entry>
  82. <entry>boolean</entry>
  83. <entry>false</entry>
  84. </row>
  85. <row>
  86. <entry>useragent</entry>
  87. <entry>ユーザエージェントを表す文字列 (リクエストヘッダに付加されます)</entry>
  88. <entry>string</entry>
  89. <entry>'Zend_Http_Client'</entry>
  90. </row>
  91. <row>
  92. <entry>timeout</entry>
  93. <entry>接続タイムアウト秒数</entry>
  94. <entry>integer</entry>
  95. <entry>10</entry>
  96. </row>
  97. <row>
  98. <entry>httpversion</entry>
  99. <entry>HTTP プロトコルのバージョン (通常は '1.1' あるいは '1.0')</entry>
  100. <entry>string</entry>
  101. <entry>'1.1'</entry>
  102. </row>
  103. <row>
  104. <entry>adapter</entry>
  105. <entry>使用する接続アダプタクラス (<xref linkend="zend.http.client.adapters" /> を参照ください)</entry>
  106. <entry>mixed</entry>
  107. <entry>'Zend_Http_Client_Adapter_Socket'</entry>
  108. </row>
  109. <row>
  110. <entry>keepalive</entry>
  111. <entry>
  112. サーバとの keep-alive 接続を有効にするかどうか。
  113. 同一サーバに連続してリクエストが発生する場合などに便利で、性能を向上させるでしょう。
  114. </entry>
  115. <entry>boolean</entry>
  116. <entry>false</entry>
  117. </row>
  118. <row>
  119. <entry>storeresponse</entry>
  120. <entry>直近のレスポンスを保存して後から
  121. getLastResponse() で取得できるようにするかどうか。false の場合
  122. getLastResponse() は null を返します。</entry>
  123. <entry>boolean</entry>
  124. <entry>true</entry>
  125. </row>
  126. </tbody>
  127. </tgroup>
  128. </table>
  129. </para>
  130. </sect2>
  131. <sect2 id="zend.http.client.basic-requests">
  132. <title>基本的な HTTP リクエストの処理</title>
  133. <para>
  134. シンプルな HTTP リクエストを実行するのは非常に簡単で、単に
  135. request() メソッドを実行するだけです。たったの三行ですんでしまいます。
  136. <example id="zend.http.client.basic-requests.example-1">
  137. <title>シンプルな GET リクエストの処理</title>
  138. <programlisting role="php"><![CDATA[
  139. $client = new Zend_Http_Client('http://example.org');
  140. $response = $client->request();
  141. ]]>
  142. </programlisting>
  143. </example>
  144. request() メソッドには、オプションでパラメータを指定することができます。
  145. このパラメータはリクエストメソッドで、HTTP プロトコルで定義されている
  146. GET、POST、PUT、HEAD、DELETE、TRACE、OPTIONS そして CONNECT
  147. のいずれかを指定可能です。
  148. <footnote>
  149. <para>
  150. RFC 2616 - <ulink url="http://www.w3.org/Protocols/rfc2616/rfc2616.html" /> を参照ください。
  151. </para>
  152. </footnote>.
  153. 利便性を高めるため、これらはすべてクラス定数として定義されています。たとえば
  154. Zend_Http_Client::GET、Zend_Http_Client::POST などのようになっています。
  155. </para>
  156. <para>
  157. メソッドを指定しない場合は、直近の setMethod() コールで指定されたメソッドを使用します。
  158. setMethod() もコールされていない場合は、デフォルトのリクエストメソッドとして
  159. GET を使用します (上の例を参照ください)。
  160. <example id="zend.http.client.basic-requests.example-2">
  161. <title>GET 以外のリクエストメソッドの使用</title>
  162. <programlisting role="php"><![CDATA[
  163. // POST リクエストを実行します
  164. $response = $client->request('POST');
  165. // POST リクエストを実行するためのもうひとつの方法です
  166. $client->setMethod(Zend_Http_Client::POST);
  167. $response = $client->request();
  168. ]]>
  169. </programlisting>
  170. </example>
  171. </para>
  172. </sect2>
  173. <sect2 id="zend.http.client.parameters">
  174. <title>GET や POST へのパラメータの追加</title>
  175. <para>
  176. GET パラメータを HTTP リクエストに追加するのは簡単です。
  177. URL の一部として指定するか、あるいは setParameterGet() メソッドを使用します。
  178. このメソッドは、GET パラメータの名前を最初の引数、そして
  179. GET パラメータの値を二番目の引数として受け取ります。
  180. さらに便利に使用するため、setParameterGet()
  181. メソッドでは name => value 形式の連想配列で GET 変数を指定することもできます。
  182. これは、複数の GET パラメータを指定する必要がある場合に便利です。
  183. <example id="zend.http.client.parameters.example-1">
  184. <title>GET パラメータの設定</title>
  185. <programlisting role="php"><![CDATA[
  186. // setParameterGet メソッドで GET パラメータを指定します
  187. $client->setParameterGet('knight', 'lancelot');
  188. // このような URL を指定するのと同じことです
  189. $client->setUri('http://example.com/index.php?knight=lancelot');
  190. // 複数のパラメータを一度に追加します
  191. $client->setParameterGet(array(
  192. 'first_name' => 'Bender',
  193. 'middle_name' => 'Bending'
  194. 'made_in' => 'Mexico',
  195. ));
  196. ]]>
  197. </programlisting>
  198. </example>
  199. </para>
  200. <para>
  201. GET パラメータはあらゆるリクエストメソッドで送信できますが、
  202. POST パラメータは POST リクエストの本文としてしか送信できません。
  203. POST パラメータをリクエストに追加する方法は、GET
  204. パラメータを追加する場合と非常に似ています。
  205. 使用するのは setParameterPost() メソッドで、このメソッドの使用法は
  206. setParameterGet() メソッドと同じです。
  207. <example id="zend.http.client.parameters.example-2">
  208. <title>POST パラメータの設定</title>
  209. <programlisting role="php"><![CDATA[
  210. // POST パラメータを設定します
  211. $client->setParameterPost('language', 'fr');
  212. // 複数の POST パラメータを設定します。そのうちのひとつは複数の値を持ちます。
  213. $client->setParameterPost(array(
  214. 'language' => 'es',
  215. 'country' => 'ar',
  216. 'selection' => array(45, 32, 80)
  217. ));
  218. ]]>
  219. </programlisting>
  220. </example>
  221. POST リクエストを送信する際には、GET パラメータと POST
  222. パラメータの両方を設定できることに注意しましょう。
  223. 一方、POST パラメータを POST 以外のリクエストで指定しても何のエラーも発生しませんが、
  224. これは無意味です。POST 以外のリクエストでは、
  225. POST パラメータを指定しても無視されます。
  226. </para>
  227. </sect2>
  228. <sect2 id="zend.http.client.accessing_last">
  229. <title>直近のリクエストやレスポンスへのアクセス</title>
  230. <para>
  231. Zend_Http_Client では、そのクライアントオブジェクトが
  232. 直近に送信したリクエストおよび
  233. 直近に受信したレスポンスにアクセスするためのメソッドを提供しています。
  234. <classname>Zend_Http_Client->getLastRequest()</classname>
  235. は何もパラメータを受け取らず、クライアントが直近に送信した
  236. HTTP リクエストを文字列で返します。同様に
  237. <classname>Zend_Http_Client->getLastResponse()</classname> は、
  238. クライアントが直近に受信した HTTP レスポンスを
  239. <link linkend="zend.http.response">Zend_Http_Response</link>
  240. オブジェクトで返します。
  241. </para>
  242. </sect2>
  243. </sect1>
  244. <!--
  245. vim:se ts=4 sw=4 et:
  246. -->