1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect3 id="zend.controller.plugins.standard.puthandler">
<title>Zend_Controller_Plugin_PutHandler</title>
<para>
<classname>Zend_Controller_Plugin_PutHandler</classname> fournit un plugin intégré pour
la gestion du corps des requêtes <constant>PUT</constant> en tant que paramètres de
requête, tout comme le corps d'une requête <constant>POST</constant>. Il va inspecter
la requête et, s'il s'agit d'une requête <constant>PUT</constant>, va utiliser la
fonction parse_str pour découper le contenu brut de la requête <constant>PUT</constant>
en un tableau de paramètres qui est ensuite enregistré dans l'objet de requête. Par
exemple :
</para>
<programlisting language="txt"><![CDATA[
PUT /notes/5.xml HTTP/1.1
title=Hello&body=World
]]></programlisting>
<para>
Pour recevoir les paramètres "title" et "body" comme des paramètres de requête habituels,
vous devez enregistrer le plugin :
</para>
<programlisting language="php"><![CDATA[
$front = Zend_Controller_Front::getInstance();
$front->registerPlugin(new Zend_Controller_Plugin_PutHandler());
]]></programlisting>
<para>
Ensuite vous pouvez accéder aux paramètres du corps de la requête <constant>PUT</constant>
par leur nom à l'intérieur de votre contrôleur :
</para>
<programlisting language="php"><![CDATA[
...
public function putAction()
{
$title = $this->getRequest()->getParam('title'); // $title = "Hello"
$body = $this->getRequest()->getParam('body'); // $body = "World"
}
...
]]></programlisting>
</sect3>
|