Zend_View-Controllers.xml 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <!-- EN-Revision: 14050 -->
  2. <sect1 id="zend.view.controllers">
  3. <title>Scripts de contrôleur</title>
  4. <para>Le contrôleur est l'endroit où vous instanciez et configurez <classname>Zend_View</classname>. Vous assignez ensuite des
  5. variables à la vue, et lui dites comment effectuer le rendu en utilisant un script particulier.</para>
  6. <sect2 id="zend.view.controllers.assign">
  7. <title>Assigner des variables</title>
  8. <para>Votre script de contrôleur devrait assigner les variables nécessaires à la vue avant de passer le contrôle
  9. au script de vue. Normalement vous pouvez faire les assignations une par une en assignant les noms des
  10. propriétés de l'instance de la vue :</para>
  11. <programlisting role="php"><![CDATA[
  12. $view = new Zend_View();
  13. $view->a = "Ha";
  14. $view->b = "Bé";
  15. $view->c = "Cé";
  16. ]]></programlisting>
  17. <para>Cependant, ceci peut être pénible quand vous avez déjà collecté (dans un tableau ou dans un objet) les
  18. valeurs à assigner.</para>
  19. <para>La méthode <code>assign()</code> vous laisse assigner "en vrac" depuis un tableau ou un objet. Les
  20. exemples suivants ont le même effet que celui ci-dessus.</para>
  21. <programlisting role="php"><![CDATA[
  22. $view = new Zend_View();
  23. // assigne un tableau de paires clés/valeurs, où la clé
  24. // est le nom de la variable, et la valeur, sa valeur assignée
  25. $array = array(
  26. 'a' => "Ha",
  27. 'b' => "Bé",
  28. 'c' => "Cé",
  29. );
  30. $view->assign($array);
  31. // fait pareil avec les propriétés publiques d'un objet
  32. // notez le transtypage lors de l'assignation
  33. $obj = new StdClass;
  34. $obj->a = "Ha";
  35. $obj->b = "Bé";
  36. $obj->c = "Cé";
  37. $view->assign((array) $obj);
  38. ]]></programlisting>
  39. <para>Alternativement, vous pouvez utiliser la méthode <code>assign()</code> pour assigner les variables une par
  40. une, en passant le nom de la variable, et sa valeur.</para>
  41. <programlisting role="php"><![CDATA[
  42. $view = new Zend_View();
  43. $view->assign('a', "Ha");
  44. $view->assign('b', "Bé");
  45. $view->assign('c', "Cé");
  46. ]]></programlisting>
  47. </sect2>
  48. <sect2 id="zend.view.controllers.render">
  49. <title>Effectuer le rendu d'un script de vue</title>
  50. <para>Une fois que vous avez assigné toutes les variables dont vous avez besoin, le contrôleur devrait demander
  51. à <classname>Zend_View</classname> de rendre un script de vue particulier. Faites cela en appelant la méthode
  52. <code>render()</code>. Notez que la méthode va retourner la vue rendue, mais ne va pas l'afficher, vous devez
  53. donc l'afficher vous même avec <code>print</code> ou <code>echo</code>, au moment voulu.</para>
  54. <programlisting role="php"><![CDATA[
  55. $view = new Zend_View();
  56. $view->a = "Ha";
  57. $view->b = "Bé";
  58. $view->c = "Cé";
  59. echo $view->render('uneVue.php');
  60. ]]></programlisting>
  61. </sect2>
  62. <sect2 id="zend.view.controllers.script-paths">
  63. <title>Chemin des scripts de vue</title>
  64. <para>Par défaut, <classname>Zend_View</classname> s'attend à ce que vos scripts de vues soient dans le même dossier que
  65. celui du contrôleur. Par exemple, si le script du contrôleur est dans "/chemin/des/controleurs" et qu'il appelle
  66. <code>$view-&gt;render('uneVue.php')</code>, <classname>Zend_View</classname> va rechercher
  67. "/chemin/des/controleurs/uneVue.php".</para>
  68. <para>Évidemment, vos scripts sont peut-être localisés ailleurs. Pour dire à <classname>Zend_View</classname> ou il doit
  69. chercher, utilisez la méthode <code>setScriptPath()</code>.</para>
  70. <programlisting role="php"><![CDATA[
  71. $view = new Zend_View();
  72. $view->setScriptPath('/chemin/des/vues');
  73. ]]></programlisting>
  74. <para>Maintenant, vous appelez <code>$view-&gt;render('uneVue.php')</code>, il va rechercher dans
  75. "<filename>/chemin/des/vues/uneVue.php</filename>".</para>
  76. <para>En fait, vous pouvez "empiler" les chemins en utilisant la méthode <code>setScriptPath()</code>. Comme
  77. vous ajoutez des chemins dans la pile, <classname>Zend_View</classname> va rechercher le script de vue dans le chemin le
  78. plus récemment ajouté. Cela vous permet de passer outre les vues par défaut, pour des vues personnalisées. Ainsi
  79. vous pouvez créer des "thèmes" ou des "skins" pour certaines vues, pendant que vous laissez les autres
  80. intactes.</para>
  81. <programlisting role="php"><![CDATA[
  82. $view = new Zend_View();
  83. $view->addScriptPath('/chemin/des/vues');
  84. $view->addScriptPath('/chemin/des/vues-personnalisees');
  85. // maintenant, lorsque vous appelerez $view->render('listelivre.php'),
  86. // Zend_View va rechercher en premier dans
  87. // "/chemin/des/vues-personnalisees/listelivre.php", puis
  88. // dans "/chemin/des/vues/listelivre.php", et ensuite dans le répertoire
  89. // courant pour trouver le fichier "listelivre.php".
  90. ]]></programlisting>
  91. <note>
  92. <title>Ne jamais utiliser une entrée utilisateur pour spécifier les chemins vers les scripts de vues</title>
  93. <para><classname>Zend_View</classname> utilise des chemins dans lesquels elle cherche et effectue le rendu des scripts
  94. de vues. En soi, ces dossiers devraient être connus à l'avance, et sous votre contrôle. <emphasis>Ne
  95. jamais</emphasis> spécifier des dossiers de scripts de vues sur la base d'une entrée utilisateur, car vous
  96. pourriez ainsi avoir une vulnérabilité d'inclusion de fichier non voulu si les chemins spécifiés par
  97. l'utilisateur sont traversant. Par exemple, le code suivant peut générer un problème :</para>
  98. <programlisting role="php"><![CDATA[
  99. // $_GET['foo'] == '../../../etc'
  100. $view->addScriptPath($_GET['foo']);
  101. $view->render('passwd');
  102. ]]></programlisting>
  103. <para>De la manière dont cet exemple est conçu, il montre clairement le problème potentiel. Si vous
  104. <emphasis>devez</emphasis> compter sur l'entrée d'utilisateur pour placer votre chemin de scripts, filtrez
  105. correctement l'entrée et contrôlez pour vous assurer que ces chemins sont contrôlés par votre
  106. application.</para>
  107. </note>
  108. </sect2>
  109. </sect1>