Zend_Http_Client.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 21821 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.http.client">
  5. <title>Einführung</title>
  6. <para>
  7. <classname>Zend_Http_Client</classname> stellt eine einfache Schnittstelle für das
  8. Durchführen von Hyper-Text Transfer Protocol (HTTP) Anfragen.
  9. <classname>Zend_Http_Client</classname> unterstützt die meisten einfachen Funktionen, die
  10. man von einem <acronym>HTTP</acronym> Client erwartet, sowie einige komplexere Funktionen,
  11. wie z.B. <acronym>HTTP</acronym> Authentifizierung und Dateiuploads. Erfolgreiche Anfragen
  12. (und die meisten nicht erfolgreichen ebenfalls) liefern ein
  13. <classname>Zend_Http_Response</classname> Objekt zurück, welches den Zugriff auf die Header
  14. und den Hauptteil der Antwort ermöglichen (siehe <xref linkend="zend.http.response" />).
  15. </para>
  16. <sect2 id="zend.http.client.usage">
  17. <title>Zend_Http_Client verwenden</title>
  18. <para>
  19. Der Klassenkonstruktor akzeptiert optional eine URL als seinen ersten Parameter (kann
  20. entweder ein String oder ein <classname>Zend_Uri_Http</classname> Objekt sein) und ein
  21. Array oder <classname>Zend_Config</classname> Objekt welches Konfigurationsparameter
  22. enthält. Beides kann ausgelassen und später durch Verwendung der setUri() and
  23. setConfig() Methoden gesetzt werden.
  24. <example id="zend.http.client.introduction.example-1">
  25. <title>Ein Zend_Http_Client Objekt instanzieren</title>
  26. <programlisting language="php"><![CDATA[
  27. $client = new Zend_Http_Client('http://example.org', array(
  28. 'maxredirects' => 0,
  29. 'timeout' => 30));
  30. // Dies macht genau das selbe:
  31. $client = new Zend_Http_Client();
  32. $client->setUri('http://example.org');
  33. $client->setConfig(array(
  34. 'maxredirects' => 0,
  35. 'timeout' => 30));
  36. // Man kann auch ein Zend_Config Objekt verwenden um die Konfiguration
  37. // des Clients zu setzen
  38. $config = new Zend_Config_Ini('httpclient.ini, 'secure');
  39. $client->setConfig($config);
  40. ]]></programlisting>
  41. </example>
  42. <note>
  43. <para>
  44. <classname>Zend_Http_Client</classname> verwendet
  45. <classname>Zend_Uri_Http</classname> um URLs zu prüfen. Das bedeutet das einige
  46. spezielle Zeichen wie das Pipe-Symbol ('|') oder das Karet Symbol ('^') in der
  47. URL standardmäßig nicht akzeptiert werden. Das kann geändert werden indem die
  48. 'allow_unwise' Option von <classname>Zend_Uri</classname> auf
  49. '<constant>TRUE</constant>' gesetzt wird. Siehe <xref
  50. linkend="zend.uri.validation.allowunwise" /> für mehr Informationen.
  51. </para>
  52. </note>
  53. </para>
  54. </sect2>
  55. <sect2 id="zend.http.client.configuration">
  56. <title>Konfigurationsparameter</title>
  57. <para>
  58. Der Konstruktor und die setConfig() Methode akzeptieren ein assoziatives Array mit
  59. Konfigurationsparametern oder ein <classname>Zend_Config</classname> Objekt. Das Setzen
  60. dieser Parameter ist optional, da alle einen Standardwert haben.
  61. <table id="zend.http.client.configuration.table">
  62. <title>Zend_Http_Client Konfigurationsparameter</title>
  63. <tgroup cols="4">
  64. <thead>
  65. <row>
  66. <entry>Parameter</entry>
  67. <entry>Beschreibung</entry>
  68. <entry>Erwartete Werte</entry>
  69. <entry>Standardwert</entry>
  70. </row>
  71. </thead>
  72. <tbody>
  73. <row>
  74. <entry>maxredirects</entry>
  75. <entry>Maximale Anzahl von zu folgenden Umleitungen (0 = keine)</entry>
  76. <entry>integer</entry>
  77. <entry>5</entry>
  78. </row>
  79. <row>
  80. <entry>strict</entry>
  81. <entry>
  82. Ob Prüfungen an Headernamen durchzuführen sind. Einige
  83. Prüf-Funktionen werden übersprungen wenn auf
  84. <constant>FALSE</constant> gesetzt. Sollte normalerweise nicht
  85. geändert werden
  86. </entry>
  87. <entry>boolean</entry>
  88. <entry><constant>TRUE</constant></entry>
  89. </row>
  90. <row>
  91. <entry>strictredirects</entry>
  92. <entry>
  93. Ob beim Umleiten genau dem <acronym>RFC</acronym> zu folgen ist
  94. (siehe <xref linkend="zend.http.client.redirections" />)
  95. </entry>
  96. <entry>boolean</entry>
  97. <entry><constant>FALSE</constant></entry>
  98. </row>
  99. <row>
  100. <entry>useragent</entry>
  101. <entry>
  102. String zur Identifizierung des User Agents (gesendet in den
  103. Anfrageheadern)
  104. </entry>
  105. <entry>string</entry>
  106. <entry>'Zend_Http_Client'</entry>
  107. </row>
  108. <row>
  109. <entry>timeout</entry>
  110. <entry>Zeitüberschreitung für Verbindungen (Sekunden)</entry>
  111. <entry>integer</entry>
  112. <entry>10</entry>
  113. </row>
  114. <row>
  115. <entry>httpversion</entry>
  116. <entry>
  117. Version des HTTP Protokolls (normalerweise '1.1' oder '1.0')
  118. </entry>
  119. <entry>string</entry>
  120. <entry>'1.1'</entry>
  121. </row>
  122. <row>
  123. <entry>adapter</entry>
  124. <entry>
  125. Zu verwendene Adapterklasse für die Verbindung (siehe
  126. <xref linkend="zend.http.client.adapters" />)
  127. </entry>
  128. <entry>mixed</entry>
  129. <entry>'Zend_Http_Client_Adapter_Socket'</entry>
  130. </row>
  131. <row>
  132. <entry>keepalive</entry>
  133. <entry>
  134. Ob keep-alive Verbindungen mit dem Server aktiviert werden sollen.
  135. Nützlich und kann die Performance verbessern, wenn mehrere
  136. aufeinanderfolgend Anfragen an den selben Server ausgeführt werden.
  137. </entry>
  138. <entry>boolean</entry>
  139. <entry><constant>FALSE</constant></entry>
  140. </row>
  141. <row>
  142. <entry>storeresponse</entry>
  143. <entry>
  144. Ob die letzte Antwort für einen späteren Aufruf von
  145. <methodname>getLastResponse()</methodname> gespeichert werden soll.
  146. Wird sie auf <constant>FALSE</constant> gesetzt gibt
  147. <methodname>getLastResponse()</methodname> <constant>NULL</constant>
  148. zurück.
  149. </entry>
  150. <entry>boolean</entry>
  151. <entry><constant>TRUE</constant></entry>
  152. </row>
  153. <row>
  154. <entry>encodecookies</entry>
  155. <entry>
  156. Ob der Cookie Wert über urlencode oder urldecode übergeben werden
  157. soll oder nicht. Dessen Aktivierung verhindert die Unterstützung
  158. bei einigen Web Servern. Dessen Deaktivierung limitiert den
  159. Bereich der Werte die Cookies enthalten können.
  160. </entry>
  161. <entry>boolean</entry>
  162. <entry><constant>TRUE</constant></entry>
  163. </row>
  164. </tbody>
  165. </tgroup>
  166. </table>
  167. </para>
  168. </sect2>
  169. <sect2 id="zend.http.client.basic-requests">
  170. <title>Durchführen von einfachen HTTP Anfragen</title>
  171. <para>
  172. Das Durchführen von einfachen HTTP Anfragen kann sehr leicht durch Verwendung der
  173. request() Methode gemacht werden und benötigt selten mehr als drei Codezeilen:
  174. <example id="zend.http.client.basic-requests.example-1">
  175. <title>Durchführen einer einfache GET Anfrage</title>
  176. <programlisting language="php"><![CDATA[
  177. $client = new Zend_Http_Client('http://example.org');
  178. $response = $client->request();
  179. ]]></programlisting>
  180. </example>
  181. Die request() Methode akzeptiert einen optionalen Parameter - die Anfragemethode.
  182. Diese kann GET, POST, PUT, HEAD, DELETE, TRACE, OPTIONS oder CONNECT sein, wie im HTTP
  183. Protokoll definiert.
  184. <footnote>
  185. <para>
  186. Siehe RFC 2616 - <ulink
  187. url="http://www.w3.org/Protocols/rfc2616/rfc2616.html" />.
  188. </para>
  189. </footnote>.
  190. Zur Erleichterung sind alle als Klassenkonstanten definiert:
  191. Zend_Http_Client::GET, Zend_Http_Client::POST und so weiter.
  192. </para>
  193. <para>
  194. Wenn keine Methode angegeben worden ist, wird die durch den letzten Aufruf von
  195. setMethod() gesetzte Methode verwendet. Wenn setMethod() vorher nicht aufgerufen worden
  196. ist, wird als Standardmethode GET verwendet (siehe obiges Beispiel).
  197. <example id="zend.http.client.basic-requests.example-2">
  198. <title>Andere Anfragemethoden als GET verwenden</title>
  199. <programlisting language="php"><![CDATA[
  200. // Durchführen einer POST Anfrage
  201. $response = $client->request('POST');
  202. // Ein weiterer Weg, eine POST Anfrage durchzuführen
  203. $client->setMethod(Zend_Http_Client::POST);
  204. $response = $client->request();
  205. ]]></programlisting>
  206. </example>
  207. </para>
  208. </sect2>
  209. <sect2 id="zend.http.client.parameters">
  210. <title>Hinzufügen von GET und POST Parametern</title>
  211. <para>
  212. Das Hinzufügen von GET Parametern zu einer HTTP Anfrage ist recht einfach und kann
  213. entweder über die Angabe als Teil der URL oder durch Verwendung der setParameterGet()
  214. Methode erfolgen.
  215. Diese Methode benötigt den Namen des GET Parameter als seinen ersten Parameter und den
  216. Wert des GET Parameter als seinen zweiten Parameter. Zur Erleichterung akzeptiert die
  217. setParameterGet() Methode auch ein einzelnes assoziatives Array mit GET Parameter als
  218. Name => Wert Variablen, was beim setzen von mehreren GET Parametern komfortabler sein
  219. kann.
  220. <example id="zend.http.client.parameters.example-1">
  221. <title>Setzen von GET Parametern</title>
  222. <programlisting language="php"><![CDATA[
  223. // Setzen eines GET Parameter mit der setParameterGet Methode
  224. $client->setParameterGet('knight', 'lancelot');
  225. // Dies ist äquivalent durch Setzen der URL:
  226. $client->setUri('http://example.com/index.php?knight=lancelot');
  227. // Hinzufügen mehrerer Parameter durch einen Aufruf
  228. $client->setParameterGet(array(
  229. 'first_name' => 'Bender',
  230. 'middle_name' => 'Bending'
  231. 'made_in' => 'Mexico',
  232. ));
  233. ]]></programlisting>
  234. </example>
  235. </para>
  236. <para>
  237. Während GET Parameter bei jeder Anfragemethode gesetzt werden können, können POST
  238. Parameter nur im Hauptteil von POST Anfragen versendet werden. Das Hinzufügen von POST
  239. Parameter zu einer Anfrage ist sehr ähnlich wie das Hinzufügen von GET Parametern and
  240. kann mit der setParameterPost() Methode gemacht werden, die vom Aufbau der
  241. setParameterGet() Methode ähnlich ist..
  242. <example id="zend.http.client.parameters.example-2">
  243. <title>Setzen von POST Parametern</title>
  244. <programlisting language="php"><![CDATA[
  245. // Setzen eines POST Parameters
  246. $client->setParameterPost('language', 'fr');
  247. // Hinzufügen von mehreren POST Parametern, eines davon mit mehreren Werten
  248. $client->setParameterPost(array(
  249. 'language' => 'es',
  250. 'country' => 'ar',
  251. 'selection' => array(45, 32, 80)
  252. ));
  253. ]]></programlisting>
  254. </example>
  255. Beim Senden einer POST Anfrage ist zu beachten, dass man sowohl GET als auch POST
  256. Parameter setzen kann. Auf der anderen Seite wird durch das Setzen von POST Parametern
  257. für andere Anfragen als POST kein Fehler ausgeworfen. Solange eine Anfrage keine POST
  258. Anfrage ist, werden POST Parameter einfach ignoriert.
  259. </para>
  260. </sect2>
  261. <sect2 id="zend.http.client.accessing_last">
  262. <title>Zugriff auf die Letzte Anfrage und Antwort</title>
  263. <para>
  264. <classname>Zend_Http_Client</classname> bietet Methoden um Zugriff auf die letzte
  265. gesendete Anfrage und die letzte empfangene Antwort des Client Objekts zu bekommen.
  266. <classname>Zend_Http_Client->getLastRequest()</classname> hat keine Parameter und gibt
  267. die letzte <acronym>HTTP</acronym> Anfrage als String zurück die der Client gesendet
  268. hat. Auf die gleiche Art und Weise gibt
  269. <classname>Zend_Http_Client->getLastResponse()</classname> die letzte
  270. <acronym>HTTP</acronym> Antwort als <link
  271. linkend="zend.http.response">Zend_Http_Response</link> Objekt zurück die der Client
  272. empfangen hat.
  273. </para>
  274. </sect2>
  275. </sect1>