Zend_Http_Response.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17175 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.http.response">
  5. <title>Zend_Http_Response</title>
  6. <sect2 id="zend.http.response.introduction">
  7. <title>Einführung</title>
  8. <para>
  9. <classname>Zend_Http_Response</classname> stellt den einfachen Zugriff auf eine
  10. <acronym>HTTP</acronym> Rückantwort sowie einige statische Methoden zum Analysieren der
  11. <acronym>HTTP</acronym> Rückantworten bereit. Normalerweise wird
  12. <classname>Zend_Http_Response</classname> als ein Objekt verwendet, dass von einer
  13. <classname>Zend_Http_Client</classname> Anfrage zurückgegeben wurde.
  14. </para>
  15. <para>
  16. In den meisten Fällen wird ein Zend_Http_Response Objekt über die factory() Methode
  17. instanziert, die einen String liest, der eine HTTP Rückantwort enthält und ein
  18. Zend_Http_Response Objekt zurückgibt.
  19. <example id="zend.http.response.introduction.example-1">
  20. <title>Ein Zend_Http_Response Object über die factory Methode instanzieren</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. Man kann auch die Konstruktormethode verwenden, um ein neues Response Objekt zu
  37. erstellen, indem man alle Parameter für die Antwort angibt:
  38. </para>
  39. <para>
  40. <code>
  41. public function __construct($code, $headers, $body = null, $version = '1.1',
  42. $message = null)
  43. </code>
  44. </para>
  45. <itemizedlist>
  46. <listitem>
  47. <para>
  48. <varname>$code</varname>: Der <acronym>HTTP</acronym> Antwortcode(eg. 200, 404,
  49. etc.)
  50. </para>
  51. </listitem>
  52. <listitem>
  53. <para>
  54. <varname>$headers</varname>: Ein assoziatives Array mit <acronym>HTTP</acronym>
  55. Antwort Headers (z.B. 'Host' => 'example.com')
  56. </para>
  57. </listitem>
  58. <listitem>
  59. <para>
  60. <varname>$body</varname>: Der Hauptteil der Antwort als String
  61. </para>
  62. </listitem>
  63. <listitem>
  64. <para>
  65. <varname>$version</varname>: Der Version der <acronym>HTTP</acronym> Antwort
  66. (normalerweise 1.0 oder 1.1)
  67. </para>
  68. </listitem>
  69. <listitem>
  70. <para>
  71. <varname>$message</varname>: Die <acronym>HTTP</acronym> Rückantwort (z.B. 'OK',
  72. 'Internal Server Error'). Falls nicht angegeben, wird die Rückantwort anhand des
  73. Antwortcode gesetzt.
  74. </para>
  75. </listitem>
  76. </itemizedlist>
  77. </sect2>
  78. <sect2 id="zend.http.response.testers">
  79. <title>Boolesche Testmethoden</title>
  80. <para>
  81. Sobald ein <classname>Zend_Http_Response</classname> Objekt instantiert ist, stellt es
  82. mehrere Methoden bereit, die zum Testen des Typs der Antwort verwendet werden können.
  83. Diese geben alle ein boolesches true oder false zurück:
  84. <itemizedlist>
  85. <listitem>
  86. <para>
  87. <code>Boolean isSuccessful()</code>: Ob die Anfrage erfolgreoch war oder
  88. nicht. Gibt TRUE für <acronym>HTTP</acronym> 1xx und 2xx Antwortcodes
  89. zurück.
  90. </para>
  91. </listitem>
  92. <listitem>
  93. <para>
  94. <code>Boolean isError()</code>: Ob der Antwortcode auf einen Fehler
  95. rückschließen lässt oder nicht. Gibt TRUE für <acronym>HTTP</acronym> 4xx
  96. (Client Fehler) und 5xx (Server Fehler) Antwortcodes zurück.
  97. </para>
  98. </listitem>
  99. <listitem>
  100. <para>
  101. <code>Boolean isRedirect()</code>: Ob die Antwort eine Weiterleitung ist
  102. oder nicht. Gibt TRUE für <acronym>HTTP</acronym> 3xx Antwortcodes zurück.
  103. </para>
  104. </listitem>
  105. </itemizedlist>
  106. <example id="zend.http.response.testers.example-1">
  107. <title>Die isError() Method verwenden, um eine Antwort zu validieren</title>
  108. <programlisting language="php"><![CDATA[
  109. if ($response->isError()) {
  110. echo "Error transmitting data.\n"
  111. echo "Server reply was: " . $response->getStatus() .
  112. " " . $response->getMessage() . "\n";
  113. }
  114. // .. verarbeite die Antwort hier...
  115. ]]></programlisting>
  116. </example>
  117. </para>
  118. </sect2>
  119. <sect2 id="zend.http.response.acessors">
  120. <title>Zugriffsmethoden</title>
  121. <para>
  122. Der Hauptzweck eines Response Okjektes ist der einfache Zugriff auf diverse
  123. Antwortparameter.
  124. <itemizedlist>
  125. <listitem>
  126. <para>
  127. <code>int getStatus()</code>: Erhalte den <acronym>HTTP</acronym>
  128. Antwortstatuscode (z.B. 200, 504, etc.) zurück
  129. </para>
  130. </listitem>
  131. <listitem>
  132. <para>
  133. <code>string getMessage()</code>: Erhalte die <acronym>HTTP</acronym>
  134. Antwortstatus Meldung (z.B. "Not Found", "Authorization Required") zurück.
  135. </para>
  136. </listitem>
  137. <listitem>
  138. <para>
  139. <code>string getBody()</code>: Erhalte den kompletten dekodierten Hauptteil
  140. der <acronym>HTTP</acronym> Antwort zurück
  141. </para>
  142. </listitem>
  143. <listitem>
  144. <para>
  145. <code>string getRawBody()</code>: Erhalte die rohen, möglicherweise
  146. kodierten Hauptteil der <acronym>HTTP</acronym> Antwort zurück. Wenn der
  147. Hauptteil z.B. mittels GZIP kodiert wurde, wird er nicht dekodiert.
  148. </para>
  149. </listitem>
  150. <listitem>
  151. <para>
  152. <code>array getHeaders()</code>: Erhalte die <acronym>HTTP</acronym> Antwort
  153. Header als assoziatives Array (z.B. 'Content-type' => 'text/html') zurück.
  154. </para>
  155. </listitem>
  156. <listitem>
  157. <para>
  158. <code>string|array getHeader($header)</code>: Erhalte einen spezifischen
  159. <acronym>HTTP</acronym> Antwort Header zurück, der durch $header angegeben
  160. wird.
  161. </para>
  162. </listitem>
  163. <listitem>
  164. <para>
  165. <code>string getHeadersAsString($status_line = true, $br = "\n")</code>:
  166. Erhalte den kompletten Header Satz als String zurück. Wenn $status_line
  167. auf true gesetzt ist (Standardwert), wird die erste Statuszeile (z.B.
  168. "HTTP/1.1 200 OK") ebenfalls zurück gegeben. Die Zeilen werden durch den
  169. $br Parameter umgebrochen (kann z.B. "&lt;br /&gt;" sein).
  170. </para>
  171. </listitem>
  172. <listitem>
  173. <para>
  174. <code>string asString($br = "\n")</code>: Erhalte die komplette Rückantwort
  175. als String zurück. Die Zeilen werden durch den $br Parameter umgebrochen
  176. (kann z.B. "&lt;br /&gt;" sein). Man kann auch die matische __toString()
  177. Methode verwenden wenn man das Objekt in einen String casten will. Diese
  178. wird dann auf asString() weiterleiten
  179. </para>
  180. </listitem>
  181. </itemizedlist>
  182. <example id="zend.http.response.acessors.example-1">
  183. <title>Zend_Http_Response Zugriffsmethoden verwenden</title>
  184. <programlisting language="php"><![CDATA[
  185. if ($response->getStatus() == 200) {
  186. echo "The request returned the following information:<br />";
  187. echo $response->getBody();
  188. } else {
  189. echo "An error occurred while fetching data:<br />";
  190. echo $response->getStatus() . ": " . $response->getMessage();
  191. }
  192. ]]></programlisting>
  193. </example>
  194. <note>
  195. <title>Immer die Rückgabewerte prüfen</title>
  196. <para>
  197. Weil eine Antwort mehrere Instanzen des selben Headers beinhalten kann, können
  198. die getHeader() Methode und getHeaders() Methode entweder einen einzelnen String
  199. oder ein Array mit Strings für jeden Header zurückgeben. Man sollte immer
  200. prüfen, ob der Rückgabewert ein String oder ein Array ist.
  201. </para>
  202. </note>
  203. <example id="zend.http.response.acessors.example-2">
  204. <title>Auf Antwort Header zugreifen</title>
  205. <programlisting language="php"><![CDATA[
  206. $ctype = $response->getHeader('Content-type');
  207. if (is_array($ctype)) $ctype = $ctype[0];
  208. $body = $response->getBody();
  209. if ($ctype == 'text/html' || $ctype == 'text/xml') {
  210. $body = htmlentities($body);
  211. }
  212. echo $body;
  213. ]]></programlisting>
  214. </example>
  215. </para>
  216. </sect2>
  217. <sect2 id="zend.http.response.static_parsers">
  218. <title>Statische HTTP Antwortanalysierer</title>
  219. <para>
  220. Die <classname>Zend_Http_Response</classname> Klasse beinhaltet auch verschiedene,
  221. intern verwendete Methoden für die Verarbeitung und Analyse der <acronym>HTTP</acronym>
  222. Rückantworten bereit. Diese Methoden sind alle als statische Methoden eingerichtet, so
  223. dass man sie extern verwenden kann, ohne dass man ein Response Objekt instanzierebn muss
  224. und nur einen bestimmten Teil der Antwort extrahieren möchte.
  225. <itemizedlist>
  226. <listitem>
  227. <para>
  228. <code>int Zend_Http_Response::extractCode($response_str)</code>: Extrahiere
  229. den <acronym>HTTP</acronym> Antwortcode (z.B. 200 oder 404) von
  230. $response_str und gebe ihn zurück.
  231. </para>
  232. </listitem>
  233. <listitem>
  234. <para>
  235. <code>string Zend_Http_Response::extractMessage($response_str)</code>:
  236. Extrahiere die <acronym>HTTP</acronym> Rückantwort (z.B. "OK" oder
  237. "File Not Found") von $response_str und gebe sie zurück.
  238. </para>
  239. </listitem>
  240. <listitem>
  241. <para>
  242. <code>string Zend_Http_Response::extractVersion($response_str)</code>: :
  243. Extrahiere die <acronym>HTTP</acronym> Version (z.B. 1.1 oder 1.0) von
  244. $response_str und gebe sie zurück.
  245. </para>
  246. </listitem>
  247. <listitem>
  248. <para>
  249. <code>array Zend_Http_Response::extractHeaders($response_str)</code>:
  250. Extrahiere die <acronym>HTTP</acronym> Antwort Header von response_str und
  251. gebe sie in einem Array zurück.
  252. </para>
  253. </listitem>
  254. <listitem>
  255. <para>
  256. <code>string Zend_Http_Response::extractBody($response_str)</code>:
  257. Extrahiere den <acronym>HTTP</acronym> Antworthauptteil aus $response_str
  258. und gebe ihn zurück.
  259. </para>
  260. </listitem>
  261. <listitem>
  262. <para>
  263. <code>string Zend_Http_Response::responseCodeAsText($code = null, $http11 =
  264. true)</code>: Erhalte die Standard <acronym>HTTP</acronym> Rückantwort für
  265. einen Antwortcode $code. Zum Beispiel wird "Internal Server Error"
  266. zurückgegeben, wenn $code gleich 500 ist. Wenn $http11 gleich true ist
  267. (Standard), werden die <acronym>HTTP</acronym>/1.1 Standardantworten zurück
  268. gegeben, andernfalls die <acronym>HTTP</acronym>/1.0 Antworten. Wird $code
  269. nicht angegeben, wird diese Methode alle bekannten <acronym>HTTP</acronym>
  270. Antwortcodes als assoziatives Array (code => message) zurückgeben.
  271. </para>
  272. </listitem>
  273. </itemizedlist>
  274. </para>
  275. <para>
  276. Neben der Analysemethoden beinhaltet die Klasse auch einen Satz von Dekodieren für
  277. allgemein <acronym>HTTP</acronym> Antwort Transferkodierungen:
  278. <itemizedlist>
  279. <listitem>
  280. <para>
  281. <code>string Zend_Http_Response::decodeChunkedBody($body)</code>: Dekodiere
  282. einen kompletten "Content-Transfer-Encoding: Chunked" Hauptteil
  283. </para>
  284. </listitem>
  285. <listitem>
  286. <para>
  287. <code>string Zend_Http_Response::decodeGzip($body)</code>: Dekodiere
  288. einen "Content-Encoding: gzip" Hauptteil
  289. </para>
  290. </listitem>
  291. <listitem>
  292. <para>
  293. <code>string Zend_Http_Response::decodeDeflate($body)</code>: Dekodiere
  294. einen "Content-Encoding: deflate" Hauptteil
  295. </para>
  296. </listitem>
  297. </itemizedlist>
  298. </para>
  299. </sect2>
  300. </sect1>
  301. <!--
  302. vim:se ts=4 sw=4 et:
  303. -->