2
0

Zend_Controller-Router-Route-Hostname.xml 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15103 -->
  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> es la ruta
  8. del framework en el servidor. Funciona similarmente a la standard route,
  9. pero funciona con el nombre del host de la <acronym>URL</acronym> llamada, en lugar del path.
  10. </para>
  11. <para>
  12. Vamos a usar el ejemplo de la standard route y ver cómo se vería con un
  13. nombre basado en host. En lugar de llamar al usuario mediante un path,
  14. quisiéramos que un usuario pueda llamar a
  15. <methodname>http://martel.users.example.com</methodname> para ver la información
  16. acerca del usuario "martel".
  17. </para>
  18. <programlisting language="php"><![CDATA[
  19. $hostnameRoute = new Zend_Controller_Router_Route_Hostname(
  20. ':username.users.example.com',
  21. array(
  22. 'controller' => 'profile',
  23. 'action' => 'userinfo'
  24. )
  25. );
  26. $plainPathRoute = new Zend_Controller_Router_Route_Static('');
  27. $router->addRoute('user', $hostnameRoute->chain($plainPathRoute);
  28. ]]></programlisting>
  29. <para>
  30. El primer parámetro del constructor en
  31. <classname>Zend_Controller_Router_Route_Hostname</classname>
  32. es una definición de ruta que será comparada con el nombre del host.
  33. Las definiciones de ruta consisten en partes estáticas y dinámicas
  34. separadas por el carácter punto ('.').
  35. Las partes dinámicas, llamadas variables, se marcan anteponiendo
  36. dos puntos (':') al nombre de la variable: <methodname>:username</methodname>.
  37. Las partes estáticas son simplemente texto: <methodname>user</methodname>.
  38. </para>
  39. <para>
  40. Las rutas del nombre del host pueden, pero nunca deben ser utilizadas así.
  41. La razón detrás de esto es que la ruta del nombre del host solamente,
  42. concordaría con cualquier path. Entonces, lo que tiene que hacer
  43. es encadenar una ruta del path a la ruta del nombre del host.
  44. Esto se hace como en el ejemplo llamando a
  45. <methodname>$hostnameRoute->chain($pathRoute);</methodname>. Haciendo esto,
  46. <methodname>$hostnameRoute</methodname> no se modifica, pero devuelve una nueva ruta
  47. (<classname>Zend_Controller_Router_Route_Chain</classname>), que luego
  48. puede ser entregada al router.
  49. </para>
  50. </sect3>
  51. <!--
  52. vim:se ts=4 sw=4 et:
  53. -->