Zend_Http_Client.xml 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 22646 -->
  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. (<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. (文字列か <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>' に設定します。詳細は <xref
  47. linkend="zend.uri.validation.allowunwise" />
  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 に厳密に従うかどうか (<xref
  92. linkend="zend.http.client.redirections" /> を参照ください)
  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. 使用する接続アダプタクラス (<xref
  119. linkend="zend.http.client.adapters" /> を参照ください)
  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>Whether to pass the cookie value through urlencode/urldecode.
  148. Enabling this breaks support with some web servers.
  149. Disabling this limits the range of values the cookies can contain.</entry>
  150. <entry>boolean</entry>
  151. <entry><constant>TRUE</constant></entry>
  152. </row>
  153. </tbody>
  154. </tgroup>
  155. </table>
  156. </para>
  157. </sect2>
  158. <sect2 id="zend.http.client.basic-requests">
  159. <title>基本的な HTTP リクエストの処理</title>
  160. <para>
  161. シンプルな <acronym>HTTP</acronym> リクエストを実行するのは非常に簡単で、単に
  162. request() メソッドを実行するだけです。たったの三行ですんでしまいます。
  163. <example id="zend.http.client.basic-requests.example-1">
  164. <title>シンプルな GET リクエストの処理</title>
  165. <programlisting language="php"><![CDATA[
  166. $client = new Zend_Http_Client('http://example.org');
  167. $response = $client->request();
  168. ]]></programlisting>
  169. </example>
  170. request() メソッドには、オプションでパラメータを指定できます。
  171. このパラメータはリクエストメソッドで、<acronym>HTTP</acronym> プロトコルで定義されている
  172. GET、POST、PUT、HEAD、DELETE、TRACE、OPTIONS そして CONNECT
  173. のいずれかを指定可能です。
  174. <footnote>
  175. <para>
  176. RFC 2616 - <ulink url="http://www.w3.org/Protocols/rfc2616/rfc2616.html" /> を参照ください。
  177. </para>
  178. </footnote>
  179. 利便性を高めるため、これらはすべてクラス定数として定義されています。たとえば
  180. Zend_Http_Client::GET、Zend_Http_Client::POST などのようになっています。
  181. </para>
  182. <para>
  183. メソッドを指定しない場合は、直近の setMethod() コールで指定されたメソッドを使用します。
  184. setMethod() もコールされていない場合は、デフォルトのリクエストメソッドとして
  185. GET を使用します (上の例を参照ください)。
  186. <example id="zend.http.client.basic-requests.example-2">
  187. <title>GET 以外のリクエストメソッドの使用</title>
  188. <programlisting language="php"><![CDATA[
  189. // POST リクエストを実行します
  190. $response = $client->request('POST');
  191. // POST リクエストを実行するためのもうひとつの方法です
  192. $client->setMethod(Zend_Http_Client::POST);
  193. $response = $client->request();
  194. ]]></programlisting>
  195. </example>
  196. </para>
  197. </sect2>
  198. <sect2 id="zend.http.client.parameters">
  199. <title>GET や POST へのパラメータの追加</title>
  200. <para>
  201. GET パラメータを <acronym>HTTP</acronym> リクエストに追加するのは簡単です。
  202. URL の一部として指定するか、あるいは setParameterGet() メソッドを使用します。
  203. このメソッドは、GET パラメータの名前を最初の引数、そして
  204. GET パラメータの値を二番目の引数として受け取ります。
  205. さらに便利に使用するため、setParameterGet()
  206. メソッドでは name => value 形式の連想配列で GET 変数を指定することもできます。
  207. これは、複数の GET パラメータを指定する必要がある場合に便利です。
  208. <example id="zend.http.client.parameters.example-1">
  209. <title>GET パラメータの設定</title>
  210. <programlisting language="php"><![CDATA[
  211. // setParameterGet メソッドで GET パラメータを指定します
  212. $client->setParameterGet('knight', 'lancelot');
  213. // このような URL を指定するのと同じことです
  214. $client->setUri('http://example.com/index.php?knight=lancelot');
  215. // 複数のパラメータを一度に追加します
  216. $client->setParameterGet(array(
  217. 'first_name' => 'Bender',
  218. 'middle_name' => 'Bending'
  219. 'made_in' => 'Mexico',
  220. ));
  221. ]]></programlisting>
  222. </example>
  223. </para>
  224. <para>
  225. GET パラメータはあらゆるリクエストメソッドで送信できますが、
  226. POST パラメータは POST リクエストの本文としてしか送信できません。
  227. POST パラメータをリクエストに追加する方法は、GET
  228. パラメータを追加する場合と非常に似ています。
  229. 使用するのは setParameterPost() メソッドで、このメソッドの使用法は
  230. setParameterGet() メソッドと同じです。
  231. <example id="zend.http.client.parameters.example-2">
  232. <title>POST パラメータの設定</title>
  233. <programlisting language="php"><![CDATA[
  234. // POST パラメータを設定します
  235. $client->setParameterPost('language', 'fr');
  236. // 複数の POST パラメータを設定します。そのうちのひとつは複数の値を持ちます。
  237. $client->setParameterPost(array(
  238. 'language' => 'es',
  239. 'country' => 'ar',
  240. 'selection' => array(45, 32, 80)
  241. ));
  242. ]]></programlisting>
  243. </example>
  244. POST リクエストを送信する際には、GET パラメータと POST
  245. パラメータの両方を設定できることに注意しましょう。
  246. 一方、POST パラメータを POST 以外のリクエストで指定しても何のエラーも発生しませんが、
  247. これは無意味です。POST 以外のリクエストでは、
  248. POST パラメータを指定しても無視されます。
  249. </para>
  250. </sect2>
  251. <sect2 id="zend.http.client.accessing_last">
  252. <title>直近のリクエストやレスポンスへのアクセス</title>
  253. <para>
  254. <classname>Zend_Http_Client</classname> では、そのクライアントオブジェクトが
  255. 直近に送信したリクエストおよび
  256. 直近に受信したレスポンスにアクセスするためのメソッドを提供しています。
  257. <classname>Zend_Http_Client->getLastRequest()</classname>
  258. は何もパラメータを受け取らず、クライアントが直近に送信した
  259. <acronym>HTTP</acronym> リクエストを文字列で返します。同様に
  260. <classname>Zend_Http_Client->getLastResponse()</classname> は、
  261. クライアントが直近に受信した <acronym>HTTP</acronym> レスポンスを
  262. <link linkend="zend.http.response">Zend_Http_Response</link>
  263. オブジェクトで返します。
  264. </para>
  265. </sect2>
  266. </sect1>
  267. <!--
  268. vim:se ts=4 sw=4 et:
  269. -->