Zend_Http_Response.xml 14 KB

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