Zend_Controller-Router-Route-Hostname.xml 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.router.routes.hostname">
  5. <title>Zend_Controller_Router_Route_Hostname</title>
  6. <para>
  7. <classname>Zend_Controller_Router_Route_Hostname</classname> est la route par nom
  8. d'hôte du framework. Elle fonctionne de la même manière que la route standard, mais elle
  9. utilise le nom d'hôte de l'URL appelé au lieu du chemin.
  10. </para>
  11. <para>
  12. Utilisons l'exemple d'une route standard et regardons ce que cela donnerais en
  13. utilisant le nom d'hôte. Au lieu d'appeler l'utilisateur par le chemin, nous voulons être
  14. capable d'appeler <code>http://toto.users.example.com</code> pour voir les informations
  15. concernant l'utilisateur "toto"&#160;
  16. </para>
  17. <programlisting language="php"><![CDATA[
  18. $hostnameRoute = new Zend_Controller_Router_Route_Hostname(
  19. ':username.users.example.com',
  20. array(
  21. 'controller' => 'profile',
  22. 'action' => 'userinfo'
  23. )
  24. );
  25. $plainPathRoute = new Zend_Controller_Router_Route_Static('');
  26. $router->addRoute('user', $hostnameRoute->chain($plainPathRoute));
  27. ]]></programlisting>
  28. <para>
  29. Le premier paramètre dans le constructeur
  30. <classname>Zend_Controller_Router_Route_Hostname</classname> est la définition d'une route
  31. qui correspondra à un nom d'hôte. Les définitions de route consistent en des parties
  32. statiques et des parties dynamiques séparées par le caractère point ("<code>.</code>"). Les
  33. parties dynamiques, appelées variables, sont marquées en précédant le nom de variable par
  34. le caractère deux-points ("<code>:</code>")&#160;: <code>:username</code>. Les parties
  35. statiques sont de simples textes&#160;: <code>user</code>.
  36. </para>
  37. <para>
  38. Les routes par nom d'hôtes peuvent, mais ne devraient pas être utilisées comme ceci.
  39. La raison à cela est que qu'une route par nom d'hôte seule ne correspondra à aucun chemin.
  40. Donc vous devez donc chaîner le chemin d'une route à une route par nom d'hôte. Ceci est
  41. réalisé comme dans l'exemple ci-dessous en appelant
  42. <code>$hostnameRoute-&gt;chain($pathRoute);</code>. En faisant ceci,
  43. <varname>$hostnameRoute</varname> n'est pas modifié, mais une nouvelle route
  44. (<classname>Zend_Controller_Router_Route_Chain</classname>) est retournée, qui peut ainsi
  45. être fournie au routeur.
  46. </para>
  47. </sect3>