2
0

Zend_Controller-Router-Route.xml 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.router.routes.standard">
  5. <title>Zend_Controller_Router_Route</title>
  6. <para>
  7. <classname>Zend_Controller_Router_Route</classname> est la route par défaut intégrée
  8. dans le routeur de réécriture (RewriteRouter). Ce routeur combine les deux avantages que
  9. sont la simplicité d'utilisation et la flexibilité. Chaque route est définie par une
  10. correspondance d'URL, statique ou dynamique, et des valeurs par défaut peuvent être
  11. fournies, de même que des valeurs obligatoires.
  12. </para>
  13. <para>
  14. Imaginons une application ayant besoin de posséder une page en décrivant l'auteur.
  15. Nous voulons que lorsque le navigateur pointe vers
  16. <code>http://domaine.fr/auteur/martel</code>, la page d'informations en question puisse
  17. apparaître, au sujet de "martel". La route pour une telle URL pourrait être&#160;:
  18. </para>
  19. <programlisting language="php"><![CDATA[
  20. $route = new Zend_Controller_Router_Route(
  21. 'auteur/:username',
  22. array(
  23. 'controller' => 'profile',
  24. 'action' => 'userinfo'
  25. )
  26. );
  27. $router->addRoute('user', $route);
  28. ]]></programlisting>
  29. <para>
  30. Le premier paramètre du constructeur de
  31. <classname>Zend_Controller_Router_Route</classname> est la définition de la route à
  32. analyser avec l'URL. Les définitions des routes sont des parties statiques et dynamiques,
  33. séparées par des slashs ("/"). Les parties statiques sont juste du texte brut&#160;:
  34. <code>auteur</code>. Les dynamiques, appelées variables, sont repérées grâce à un caractère
  35. deux-points (:) devant la variable&#160;: <code>:username</code>.
  36. </para>
  37. <note>
  38. <title>Utilisation des caractères</title>
  39. <para>
  40. Pour identifier une variable dans un schéma de routage (après le deux-points), en
  41. théorie n'importe quel caractère fait l'affaire (sauf le slash "/"). Cependant il est
  42. conseillé de n'utiliser que des caractères que PHP comprend comme étant des noms de
  43. variables valides. Les implémentations futures de ce comportement peuvent changer,
  44. altérant ainsi votre code.
  45. </para>
  46. </note>
  47. <para>
  48. Cette route exemple devrait être utilisée lorsque le navigateur pointe vers
  49. <code>http://domaine.fr/auteur/martel</code>, et dans un tel cas, tous les paramètres de la
  50. requête seront injectés dans l'objet <classname>Zend_Controller_Request</classname> et
  51. seront accessibles à travers votre <code>ProfileController</code>. Les variables retournées
  52. par cet exemple peuvent être représentées par le tableau suivant&#160;:
  53. </para>
  54. <programlisting language="php"><![CDATA[
  55. $values = array(
  56. 'username' => 'martel',
  57. 'controller' => 'profile',
  58. 'action' => 'userinfo'
  59. );
  60. ]]></programlisting>
  61. <para>
  62. Plus tard, <classname>Zend_Controller_Dispatcher_Standard</classname> va distribuer
  63. vers la méthode <code>userinfoAction()</code> de <code>ProfileController</code> (dans le
  64. module par défaut) selon ces valeurs. A cet endroit, il sera possible d'accéder à toutes
  65. les variables de la requête grâce à
  66. <classname>Zend_Controller_Action::_getParam()</classname> ou
  67. <classname>Zend_Controller_Request::getParam()</classname>&#160;:
  68. </para>
  69. <programlisting language="php"><![CDATA[
  70. public function userinfoAction()
  71. {
  72. $request = $this->getRequest();
  73. $username = $request->getParam('username');
  74. $username = $this->_getParam('username');
  75. }
  76. ]]></programlisting>
  77. <para>
  78. La définition des routes peut contenir un ou plusieurs caractères spéciaux - des
  79. jokers - représentés par le symbole '*'. Il est utilisé pour collecter des paramètres.
  80. L'exemple suivant représente plus ou moins le comportement par défaut de la route
  81. "Module"&#160;:
  82. </para>
  83. <programlisting language="php"><![CDATA[
  84. $route = new Zend_Controller_Router_Route(
  85. ':module/:controller/:action/*',
  86. array('module' => 'default')
  87. );
  88. $router->addRoute('default', $route);
  89. ]]></programlisting>
  90. <sect4 id="zend.controller.router.routes.standard.variable-defaults">
  91. <title>Variables par défaut</title>
  92. <para>
  93. Chaque variable dynamique dans la définition des routes peut avoir une valeur par
  94. défaut. C'est à cela que sert le second paramètre du constructeur de
  95. <classname>Zend_Controller_Router_Route</classname>. Il s'agit d'un tableau avec comme
  96. clés les noms des variables, et comme valeurs, leurs valeurs par défaut&#160;:
  97. </para>
  98. <programlisting language="php"><![CDATA[
  99. $route = new Zend_Controller_Router_Route(
  100. 'archive/:annee',
  101. array('annee' => 2006)
  102. );
  103. $router->addRoute('archive', $route);
  104. ]]></programlisting>
  105. <para>
  106. L'exemple ci-dessus établira une correspondance avec les URL comme
  107. <code>http://domaine.fr/archive/2005</code> et <code>http://exemple.fr/archive</code>.
  108. Dans ce dernier cas, la variable de l'année (<code>annee</code>) aura la valeur
  109. 2006.
  110. </para>
  111. <para>
  112. L'exemple ci-dessus injecte ainsi un paramètre représentant une année
  113. (<code>annee</code>). Si aucune information de contrôleur ou d'actions n'est présente,
  114. alors ceux par défaut seront utilisés (ils sont définis dans
  115. <classname>Zend_Controller_Dispatcher_Abstract</classname>). Pour que l'exemple soit
  116. plus intuitif, spécifions des contrôleur/action par défaut dans notre route&#160;:
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. $route = new Zend_Controller_Router_Route(
  120. 'archive/:annee',
  121. array(
  122. 'annee' => 2006,
  123. 'controller' => 'archive',
  124. 'action' => 'show'
  125. )
  126. );
  127. $router->addRoute('archive', $route);
  128. ]]></programlisting>
  129. <para>
  130. Cette route va alors donner une distribution vers la méthode <code>showAction()</code>
  131. de <code>ArchiveController</code>.
  132. </para>
  133. </sect4>
  134. <sect4 id="zend.controller.router.routes.standard.variable-requirements">
  135. <title>Obligations et contraintes des variables</title>
  136. <para>
  137. Vous pouvez ajouter un troisième paramètre au constructeur de
  138. <classname>Zend_Controller_Router_Route</classname> pour spécifier une variable
  139. obligatoire. Ceci s'effectue au moyen d'expressions régulières&#160;:
  140. </para>
  141. <programlisting language="php"><![CDATA[
  142. $route = new Zend_Controller_Router_Route(
  143. 'archive/:annee',
  144. array(
  145. 'annee' => 2006,
  146. 'controller' => 'archive',
  147. 'action' => 'show'
  148. ),
  149. array('year' => '\d+')
  150. );
  151. $router->addRoute('archive', $route);
  152. ]]></programlisting>
  153. <para>
  154. Avec une telle définition de route, comme ci-dessus, le routeur n'établira une
  155. correspondance que si la variable "<code>annee</code>" contient une donnée
  156. numérique&#160;: <code>http://domaine.fr/archive/2345</code>. Une URL comme
  157. <code>http://exemple.annee/archive/test</code> ne sera pas captée (matchée) par cette
  158. route, et le contrôle sera passé à la route suivante, etc.
  159. </para>
  160. </sect4>
  161. </sect3>