Zend_Http_Client-Adapters.xml 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17405 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.http.client.adapters">
  5. <title>Zend_Http_Client - Adaptateurs de connexion</title>
  6. <sect2 id="zend.http.client.adapters.overview">
  7. <title>Présentation globale</title>
  8. <para>
  9. <classname>Zend_Http_Client</classname> accepte des objets adaptateurs. Ces objets
  10. ont la responsabilité de soutenir la connexion vers un serveur, à savoir écrire des
  11. requêtes et lire des réponses L'adaptateur peut donc être changé, et même écrit ou
  12. réécrit pour correspondre à vos besoins, sans avoir l'obligation de toucher à toute la
  13. classe dite "client". Vous vous connectez et manipulez votre connexion toujours de la
  14. même manière quelque soit l'adaptateur situé dessous.
  15. </para>
  16. <para>
  17. Actuellement, la classe cliente <classname>Zend_Http_Client</classname> est
  18. fournie avec quatre adaptateurs : <itemizedlist>
  19. <listitem>
  20. <para><classname>Zend_Http_Client_Adapter_Socket</classname> (défaut)</para>
  21. </listitem>
  22. <listitem>
  23. <para><classname>Zend_Http_Client_Adapter_Proxy</classname></para>
  24. </listitem>
  25. <listitem>
  26. <para><classname>Zend_Http_Client_Adapter_Curl</classname></para>
  27. </listitem>
  28. <listitem>
  29. <para><classname>Zend_Http_Client_Adapter_Test</classname></para>
  30. </listitem>
  31. </itemizedlist>
  32. </para>
  33. <para>
  34. L'objet Zend_Http_Client se voit spécifié un adaptateur via son constructeur avec
  35. le tableau d'options, à l'index 'adapter'. Fournissez alors une chaîne représentant la
  36. classe d'adaptateur à utiliser (par exemple 'Zend_Http_Client_Adapter_Socket'), ou un
  37. objet directement (par exemple <code> new Zend_Http_Client_Adapter_Test</code>). Vous
  38. pouvez de même passer un adaptateur plus tard, avec la méthode
  39. <classname>Zend_Http_Client-&gt;setConfig()</classname>.
  40. </para>
  41. </sect2>
  42. <sect2 id="zend.http.client.adapters.socket">
  43. <title>Adaptateur Socket</title>
  44. <para>
  45. L'adaptateur par défaut est Zend_Http_Client_Adapter_Socket. Il est basé sur les
  46. fonctions <acronym>PHP</acronym> <methodname>fsockopen()</methodname> et soeurs. Il ne nécessite donc aucune extension
  47. particulière ni option de compilation de <acronym>PHP</acronym>.
  48. </para>
  49. <para>
  50. L'adaptateur Socket peut être configuré avec des options, passées par
  51. <classname>Zend_Http_Client-&gt;setConfig()</classname> ou au constructeur du client.
  52. <table id="zend.http.client.adapter.socket.configuration.table">
  53. <title>Zend_Http_Client_Adapter_Socket configuration</title>
  54. <tgroup cols="4">
  55. <thead>
  56. <row>
  57. <entry>Paramètre</entry>
  58. <entry>Description</entry>
  59. <entry>Types attendus</entry>
  60. <entry>Valeur par défaut</entry>
  61. </row>
  62. </thead>
  63. <tbody>
  64. <row>
  65. <entry>persistent</entry>
  66. <entry>Utilise ou non les connexions <acronym>TCP</acronym> persistantes</entry>
  67. <entry>booléen</entry>
  68. <entry>false</entry>
  69. </row>
  70. <row>
  71. <entry>ssltransport</entry>
  72. <entry>Couche de transport <acronym>SSL</acronym> ('sslv2', 'tls')</entry>
  73. <entry>chaîne</entry>
  74. <entry>ssl</entry>
  75. </row>
  76. <row>
  77. <entry>sslcert</entry>
  78. <entry>Chemin vers le certificat <acronym>SSL</acronym> encodé <acronym>PEM</acronym></entry>
  79. <entry>chaîne</entry>
  80. <entry>null</entry>
  81. </row>
  82. <row>
  83. <entry>sslpassphrase</entry>
  84. <entry>Phrase de passe pour le fichier de certificat <acronym>SSL</acronym></entry>
  85. <entry>chaîne</entry>
  86. <entry>null</entry>
  87. </row>
  88. </tbody>
  89. </tgroup>
  90. </table> <note>
  91. <title>Connexions <acronym>TCP</acronym> persistantes</title>
  92. <para>
  93. L'utilisation de connexions <acronym>TCP</acronym> persistantes peut potentiellement
  94. accélérer vos requêtes <acronym>HTTP</acronym> mais n'a, dans la plupart des cas, qu'un petit effet
  95. positif et peut surcharger le serveur <acronym>HTTP</acronym> auquel vous êtes connecté.
  96. </para>
  97. <para>
  98. Il est recommandé d'utiliser les connexions <acronym>TCP</acronym> persistantes seulement si
  99. vous vous connectez au même serveur très fréquemment, et que vous êtes sûr que
  100. le serveur est capable de gérer un nombre élevé de connections concurrentes.
  101. Dans tous les cas vous êtes encouragés à tester l'effet des connections
  102. persistantes à la fois sur l'accélération du client et sur la charge du serveur
  103. avant d'activer cette option.
  104. </para>
  105. <para>
  106. De plus, quand vous utilisez des connexions persistantes, il est
  107. recommandé d'activer l'option "Keep-Alive" décrite dans <xref
  108. linkend="zend.http.client.configuration" />, sinon les connexions persistantes
  109. n'auront que peu ou pas d'effet.
  110. </para>
  111. </note> <note>
  112. <title>HTTPS SSL Paramètres de flux</title>
  113. <para>
  114. <code>ssltransport, sslcert</code> and <code>sslpassphrase</code> sont
  115. seulement appropriées lors de l'utilisation d'HTTPS.
  116. </para>
  117. <para>
  118. Bien que les réglages par défaut du mode <acronym>SSL</acronym> fonctionneront pour la
  119. plupart des applications, vous pourrez avoir besoin de les changer si le
  120. serveur, auquel vous vous connectez, requière un paramétrage particulier du
  121. client. Dans ce cas, vous devriez lire les sections sur la couche de transport
  122. <acronym>SSL</acronym> et ses options à cette <ulink
  123. url="http://www.php.net/manual/en/transports.php#transports.inet">adresse</ulink>.
  124. </para>
  125. </note>
  126. </para>
  127. <example id="zend.http.client.adapters.socket.example-1">
  128. <title>Changer la couche de transport HTTPS</title>
  129. <programlisting language="php"><![CDATA[
  130. // Définit des paramètres de configuration
  131. $config = array(
  132. 'adapter' => 'Zend_Http_Client_Adapter_Socket',
  133. 'ssltransport' => 'tls'
  134. );
  135. // Instantie un objet client
  136. $client = new Zend_Http_Client('https://www.example.com', $config);
  137. // Cette requête sera envoyée vers une connexion sécurisée TLS
  138. $response = $client->request();
  139. ]]></programlisting>
  140. </example>
  141. <para>
  142. Le résultat ci-dessus sera similaire à l'ouverture d'une connexion <acronym>TCP</acronym> avec la
  143. commande <acronym>PHP</acronym> suivante :
  144. </para>
  145. <para><methodname>fsockopen('tls://www.example.com', 443)</methodname></para>
  146. <sect3 id="zend.http.client.adapters.socket.streamcontext">
  147. <title>Customizing and accessing the Socket adapter stream context</title>
  148. <para>
  149. Starting from Zend Framework 1.9, <classname>Zend_Http_Client_Adapter_Socket</classname>
  150. provides direct access to the underlying <ulink url="http://php.net/manual/en/stream.contexts.php">stream context</ulink>
  151. used to connect to the remote server. This allows the user to pass
  152. specific options and parameters to the <acronym>TCP</acronym> stream, and to the <acronym>SSL</acronym> wrapper in
  153. case of <acronym>HTTPS</acronym> connections.
  154. </para>
  155. <para>
  156. You can access the stream context using the following methods of <classname>Zend_Http_Client_Adapter_Socket</classname>:
  157. <itemizedlist>
  158. <listitem>
  159. <para>
  160. <firstterm><methodname>setStreamContext($context)</methodname></firstterm>
  161. Sets the stream context to be used by the adapter. Can accept either
  162. a stream context resource created using the
  163. <ulink url="http://php.net/manual/en/function.stream-context-create.php"><methodname>stream_context_create()</methodname></ulink>
  164. <acronym>PHP</acronym> function, or an array of stream context options, in the same format provided to this function.
  165. Providing an array will create a new stream context using these options, and set it.
  166. </para>
  167. </listitem>
  168. <listitem>
  169. <para>
  170. <firstterm><methodname>getStreamContext()</methodname></firstterm>
  171. Get the stream context of the adapter. If no stream context was set,
  172. will create a default stream context and return it. You can then set
  173. or get the value of different context options using regular <acronym>PHP</acronym> stream
  174. context functions.
  175. </para>
  176. </listitem>
  177. </itemizedlist>
  178. </para>
  179. <example id="zend.http.client.adapters.socket.streamcontext.example-1">
  180. <title>Setting stream context options for the Socket adapter</title>
  181. <programlisting language="php"><![CDATA[
  182. // Array of options
  183. $options = array(
  184. 'socket' => array(
  185. // Bind local socket side to a specific interface
  186. 'bindto' => '10.1.2.3:50505'
  187. ),
  188. 'ssl' => array(
  189. // Verify server side certificate,
  190. // do not accept invalid or self-signed SSL certificates
  191. 'verify_peer' => true,
  192. 'allow_self_signed' => false,
  193. // Capture the peer's certificate
  194. 'capture_peer_cert' => true
  195. )
  196. );
  197. // Create an adapter object and attach it to the HTTP client
  198. $adapter = new Zend_Http_Client_Adapter_Socket();
  199. $client = new Zend_Http_Client();
  200. $client->setAdapter($adapter);
  201. // Method 1: pass the options array to setStreamContext()
  202. $adapter->setStreamContext($options);
  203. // Method 2: create a stream context and pass it to setStreamContext()
  204. $context = stream_context_create($options);
  205. $adapter->setStreamContext($context);
  206. // Method 3: get the default stream context and set the options on it
  207. $context = $adapter->getStreamContext();
  208. stream_context_set_option($context, $options);
  209. // Now, preform the request
  210. $response = $client->request();
  211. // If everything went well, you can now access the context again
  212. $opts = stream_context_get_options($adapter->getStreamContext());
  213. echo $opts['ssl']['peer_certificate'];
  214. ]]></programlisting>
  215. </example>
  216. <note>
  217. <para>
  218. Note that you must set any stream context options before using the adapter
  219. to preform actual requests. If no context is set before preforming <acronym>HTTP</acronym> requests
  220. with the Socket adapter, a default stream context will be created. This context
  221. resource could be accessed after preforming any requests using the
  222. <methodname>getStreamContext()</methodname> method.
  223. </para>
  224. </note>
  225. </sect3>
  226. </sect2>
  227. <sect2 id="zend.http.client.adapters.proxy">
  228. <title>Adaptateur Proxy</title>
  229. <para>
  230. L'adaptateur Zend_Http_Client_Adapter_Proxy est identique à celui par défaut,
  231. Socket, sauf que Proxy se connectera au serveur via un serveur Proxy (mandataire). Cette
  232. utilisation peut être rencontrée pour des raisons de performances ou de sécurité.
  233. </para>
  234. <para>
  235. En utilisant l'adaptateur Proxy, quelques paramètres de configuration seront
  236. nécessaires en plus du paramètre 'adapter' : <table
  237. id="zend.http.client.adapters.proxy.table">
  238. <title>Zend_Http_Client paramètres de configuration</title>
  239. <tgroup cols="4">
  240. <thead>
  241. <row>
  242. <entry>Paramètre</entry>
  243. <entry>Description</entry>
  244. <entry>Valeurs attendues</entry>
  245. <entry>Valeur par défaut</entry>
  246. </row>
  247. </thead>
  248. <tbody>
  249. <row>
  250. <entry>proxy_host</entry>
  251. <entry>Adresse du serveur Proxy</entry>
  252. <entry>chaîne</entry>
  253. <entry>'proxy.myhost.com' ou '10.1.2.3'</entry>
  254. </row>
  255. <row>
  256. <entry>proxy_port</entry>
  257. <entry>Port du serveur Proxy</entry>
  258. <entry>entier</entry>
  259. <entry>8080 (défaut) ou 81</entry>
  260. </row>
  261. <row>
  262. <entry>proxy_user</entry>
  263. <entry>nom d'utilisateur pour le Proxy, si requis</entry>
  264. <entry>chaîne</entry>
  265. <entry>'shahar' ou '' pour aucun (défaut)</entry>
  266. </row>
  267. <row>
  268. <entry>proxy_pass</entry>
  269. <entry>Mot de passe du Proxy, si requis</entry>
  270. <entry>chaîne</entry>
  271. <entry>'secret' ou '' pour aucun (défaut)</entry>
  272. </row>
  273. <row>
  274. <entry>proxy_auth</entry>
  275. <entry>Type d'authentification <acronym>HTTP</acronym> du Proxy</entry>
  276. <entry>chaîne</entry>
  277. <entry>Zend_Http_Client::AUTH_BASIC (défaut)</entry>
  278. </row>
  279. </tbody>
  280. </tgroup>
  281. </table>
  282. </para>
  283. <para>
  284. <code>proxy_host</code> devrait toujours être fourni. Si ça n'est pas le cas,
  285. alors le client retournera sur une connexion Socket par défaut. <code>proxy_port</code>
  286. est par défaut à "8080".
  287. </para>
  288. <para>
  289. <code>proxy_user</code> et <code>proxy_pass</code> ne sont requis que si le
  290. serveur Proxy demande une authentification. Si vous remplissez ces options, alors un
  291. champ d'en-tête <acronym>HTTP</acronym> "Proxy-Authentication" sera ajouté à vos requêtes, via votre
  292. client.
  293. </para>
  294. <para>
  295. <code>proxy_auth</code> définit le type d'authentification à utiliser, si le
  296. serveur Proxy demande une authentification. Actuellement, seule la méthode "basic"
  297. (<classname>Zend_Http_Client::AUTH_BASIC</classname>) est supportée.
  298. </para>
  299. <example id="zend.http.client.adapters.proxy.example-1">
  300. <title>Utiliser Zend_Http_Client derrière un serveur Proxy</title>
  301. <programlisting language="php"><![CDATA[
  302. // Paramètres de configuration
  303. $config = array(
  304. 'adapter' => 'Zend_Http_Client_Adapter_Proxy',
  305. 'proxy_host' => 'proxy.int.zend.com',
  306. 'proxy_port' => 8000,
  307. 'proxy_user' => 'shahar.e',
  308. 'proxy_pass' => 'bananashaped'
  309. );
  310. // Crée l'objet client
  311. $client = new Zend_Http_Client('http://www.example.com', $config);
  312. // utilisez l'objet client ici ...
  313. ]]></programlisting>
  314. </example>
  315. <para>
  316. Comme déjà dit, si proxy_host n'est pas rempli ou défini en tant que chaîne vide,
  317. alors le client utilisera l'adaptateur Socket par défaut. Ceci est utile si le proxy est
  318. utilisé optionnellement, ou par intermittence.
  319. </para>
  320. <note>
  321. <para>
  322. Since the proxy adapter inherits from <classname>Zend_Http_Client_Adapter_Socket</classname>,
  323. you can use the stream context access method (see <xref linkend="zend.http.client.adapters.socket.streamcontext" />)
  324. to set stream context options on Proxy connections as demonstrated above.
  325. </para>
  326. </note>
  327. </sect2>
  328. <sect2 id="zend.http.client.adapters.curl">
  329. <title>The cURL Adapter</title>
  330. <para>
  331. cURL is a standard <acronym>HTTP</acronym> client library that is distributed with many
  332. operating systems and can be used in <acronym>PHP</acronym> via the cURL extension. It
  333. offers functionality for many special cases which can occur for a <acronym>HTTP</acronym>
  334. client and make it a perfect choice for a <acronym>HTTP</acronym> adapter. It supports
  335. secure connections, proxy, all sorts of authentication mechanisms
  336. and shines in applications that move large files around between servers.
  337. </para>
  338. <example id="zend.http.client.adapters.curl.example-1">
  339. <title>Setting cURL options</title>
  340. <programlisting language="php"><![CDATA[
  341. $config = array(
  342. 'adapter' => 'Zend_Http_Client_Adapter_Curl',
  343. 'curloptions' => array(CURLOPT_FOLLOWLOCATION => true),
  344. );
  345. $client = new Zend_Http_Client($uri, $config);
  346. ]]></programlisting>
  347. </example>
  348. <para>
  349. By default the cURL adapter is configured to behave exactly like
  350. the Socket Adapter and it also accepts the same configuration parameters
  351. as the Socket and Proxy adapters. You can also change the cURL options by either specifying
  352. the 'curloptions' key in the constructor of the adapter or by calling
  353. <methodname>setCurlOption($name, $value)</methodname>. The <varname>$name</varname> key
  354. corresponds to the CURL_* constants of the cURL extension. You can
  355. get access to the Curl handle by calling <code>$adapter->getHandle();</code>
  356. </para>
  357. <example id="zend.http.client.adapters.curl.example-2">
  358. <title>Transfering Files by Handle</title>
  359. <para>
  360. You can use cURL to transfer very large files over <acronym>HTTP</acronym> by filehandle.
  361. </para>
  362. <programlisting language="php"><![CDATA[
  363. $putFileSize = filesize("filepath");
  364. $putFileHandle = fopen("filepath", "r");
  365. $adapter = new Zend_Http_Client_Adapter_Curl();
  366. $client = new Zend_Http_Client();
  367. $client->setAdapter($adapter);
  368. $adapter->setConfig(array(
  369. 'curloptions' => array(
  370. CURLOPT_INFILE => $putFileHandle,
  371. CURLOPT_INFILESIZE => $putFileSize
  372. )
  373. ));
  374. $client->request("PUT");
  375. ]]></programlisting>
  376. </example>
  377. </sect2>
  378. <sect2 id="zend.http.client.adapters.test">
  379. <title>Adaptateur Test</title>
  380. <para>
  381. Il est quelque fois difficile de tester une application qui a besoin d'une
  382. connexion <acronym>HTTP</acronym>. Par exemple, une application qui est en charge de lire un flux <acronym>RSS</acronym> aura
  383. besoin d'une connexion, qui n'est pas tout le temps disponible.
  384. </para>
  385. <para>
  386. C'est pour cette raison que l'adaptateur
  387. <classname>Zend_Http_Client_Adapter_Test</classname> est présent. Vous pouvez de cette
  388. manière écrire vos applications, et lors de la phase de tests, passer votre connexion
  389. sur l'adaptateur Test (objet mock).
  390. </para>
  391. <para>
  392. La classe <classname>Zend_Http_Client_Adapter_Test</classname> possède une méthode
  393. supplémentaire, <methodname>setResponse()</methodname>. Elle prend en paramètre un objet
  394. <classname>Zend_Http_Response</classname> ou une chaîne. Une fois cet objet de réponse
  395. déterminé, l'adaptateur de Test retournera toujours cette réponse, sans effectuer de
  396. réelle requête <acronym>HTTP</acronym>.
  397. </para>
  398. <example id="zend.http.client.adapters.test.example-1">
  399. <title>Tester avec un objet de réponse HTTP unique</title>
  400. <programlisting language="php"><![CDATA[
  401. // Création de l'adatateur et de l'objet client :
  402. $adapter = new Zend_Http_Client_Adapter_Test();
  403. $client = new Zend_Http_Client('http://www.example.com', array(
  404. 'adapter' => $adapter
  405. ));
  406. // Passage de l'objet de réponse
  407. $adapter->setResponse(
  408. "HTTP/1.1 200 OK" . "\r\n" .
  409. "Content-type: text/xml" . "\r\n" .
  410. "\r\n" .
  411. '<?xml version="1.0" encoding="UTF-8"?>' .
  412. '<rss version="2.0" xmlns:content="http://purl.org/rss/1.0/modules/content/"' .
  413. ' xmlns:wfw="http://wellformedweb.org/CommentAPI/"' .
  414. ' xmlns:dc="http://purl.org/dc/elements/1.1/">' .
  415. ' <channel>' .
  416. ' <title>Premature Optimization</title>' .
  417. // etc....
  418. '</rss>');
  419. $response = $client->request('GET');
  420. // ... continuez à parser $response...
  421. ]]></programlisting>
  422. </example>
  423. <para>
  424. L'exemple ci dessus montre comment préconfigurer la réponse qui sera retournée
  425. lors d'une requête de votre objet client. Ainsi lors des tests, votre application
  426. continuera de se comporter normalement, elle aura tout simplement été trompée (mock).
  427. Aucune connexion <acronym>HTTP</acronym> n'est dans ce cas là nécessaire.
  428. </para>
  429. <para>
  430. Quelques fois, plusieurs transactions <acronym>HTTP</acronym> peuvent être nécessaires. Une réponse
  431. peut demander une redirection, vers une autre. Dans ce cas, utiliser
  432. <methodname>setResponse()</methodname> toute seule n'est pas possible car il ne sera pas possible de
  433. spécifier les réponses suivantes, nécessaires alors à l'application.
  434. </para>
  435. <example id="zend.http.client.adapters.test.example-2">
  436. <title>Tester avec plusieurs réponses HTTP</title>
  437. <programlisting language="php"><![CDATA[
  438. // Création des objets adaptateur, et client
  439. $adapter = new Zend_Http_Client_Adapter_Test();
  440. $client = new Zend_Http_Client('http://www.example.com', array(
  441. 'adapter' => $adapter
  442. ));
  443. // Configuration de la première réponse attendue
  444. $adapter->setResponse(
  445. "HTTP/1.1 302 Found" . "\r\n" .
  446. "Location: /" . "\r\n" .
  447. "Content-Type: text/html" . "\r\n" .
  448. "\r\n" .
  449. '<html>' .
  450. ' <head><title>Moved</title></head>' .
  451. ' <body><p>This page has moved.</p></body>' .
  452. '</html>');
  453. // Configuration des réponses successives
  454. $adapter->addResponse(
  455. "HTTP/1.1 200 OK" . "\r\n" .
  456. "Content-Type: text/html" . "\r\n" .
  457. "\r\n" .
  458. '<html>' .
  459. ' <head><title>My Pet Store Home Page</title></head>' .
  460. ' <body><p>...</p></body>' .
  461. '</html>');
  462. // l'objet $client est prêt à être testé
  463. // son comportement est déja configuré
  464. ]]></programlisting>
  465. </example>
  466. <para>
  467. La méthode <methodname>setResponse()</methodname> détruit toutes les réponses dans le buffer
  468. de <classname>Zend_Http_Client_Adapter_Test</classname> et définit la première réponse
  469. qui sera retournée. La méthode <methodname>addResponse()</methodname> définit les réponses
  470. suivantes.
  471. </para>
  472. <para>Les réponses seront rejouées dans leur ordre d'ajout.</para>
  473. <para>
  474. Dans l'exemple ci-dessus, l'adaptateur est configuré pour un scénario de test de
  475. redirections 302. En fonction de votre application, le suivi d'une redirection peut être
  476. ou non désiré. Dans notre exemple, nous nous attendons à ce que la redirection soit
  477. suivie et nous configurons notre adaptateur de tests pour ceci. La réponse de
  478. redirection originelle (302) est définie avec la méthode <methodname>setResponse()</methodname>,
  479. quant à la réponse non redirigeante (200) suivante, elles est définie avec la méthode
  480. <methodname>addResponse()</methodname>. Lorsque votre objet client est configuré, vous pouvez
  481. l'injecter dans votre application à tester, et voir le résultat et les
  482. comportements.
  483. </para>
  484. </sect2>
  485. <sect2 id="zend.http.client.adapters.extending">
  486. <title>Créer vos propres adaptateurs de connexion</title>
  487. <para>
  488. Vous pouvez créer vos propres adaptateurs, si vous avez un besoin spécial à
  489. utiliser. Par exemple, des possibilités de cache, ou des sockets persistantes.
  490. </para>
  491. <para>
  492. Pour ceci, votre classe d'adaptateur doit implémenter l'interface
  493. <classname>Zend_Http_Client_Adapter_Interface</classname>. L'exemple suivant montre un
  494. squelette de classe. Toutes les méthodes publiques, ici, sont indispensables à la
  495. classe, elles sont issues de l'interface :
  496. </para>
  497. <example id="zend.http.client.adapters.extending.example-1">
  498. <title>Création de votre propre adaptateur de connexion</title>
  499. <programlisting language="php"><![CDATA[
  500. class MyApp_Http_Client_Adapter_BananaProtocol
  501. implements Zend_Http_Client_Adapter_Interface
  502. {
  503. /**
  504. * Définit le tableau de configuration pour cet adaptateur
  505. *
  506. * @param array $config
  507. */
  508. public function setConfig($config = array())
  509. {
  510. // Ceci change rarement, vous devriez copier l'implémentation
  511. // présente dans Zend_Http_Client_Adapter_Socket.
  512. }
  513. /**
  514. * Connecte à une serveur distant
  515. *
  516. * @param string $host
  517. * @param int $port
  518. * @param boolean $secure
  519. */
  520. public function connect($host, $port = 80, $secure = false)
  521. {
  522. // Etablit la connexion au serveur
  523. }
  524. /**
  525. * Envoie une requête au serveur
  526. *
  527. * @param string $method
  528. * @param Zend_Uri_Http $url
  529. * @param string $http_ver
  530. * @param array $headers
  531. * @param string $body
  532. * @return string Request as text
  533. */
  534. public function write($method,
  535. $url,
  536. $http_ver = '1.1',
  537. $headers = array(),
  538. $body = '')
  539. {
  540. // Envoie la requête au serveur distant. Cette fonction devrait
  541. // retourner la requête complète (en-tête et corps) as a string
  542. }
  543. /**
  544. * Lit la réponse du serveur
  545. *
  546. * @return string
  547. */
  548. public function read()
  549. {
  550. // Lit la réponse du serveur distant, et la retourne sous forme
  551. // de chaine de caractères
  552. }
  553. /**
  554. * Ferme la connexion avec le serveur
  555. *
  556. */
  557. public function close()
  558. {
  559. // Ferme la connexion, appelée en dernière.
  560. }
  561. }
  562. // Maintenant, vous pouvez utiliser cet adaptateur :
  563. $client = new Zend_Http_Client(array(
  564. 'adapter' => 'MyApp_Http_Client_Adapter_BananaProtocol'
  565. ));
  566. ]]></programlisting>
  567. </example>
  568. </sect2>
  569. </sect1>