Zend_Http_Client.xml 16 KB

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