2
0

Zend_Controller-Router-Route.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect3 id="zend.controller.router.routes.standard">
  4. <title>Zend_Controller_Router_Route</title>
  5. <para>
  6. <classname>Zend_Controller_Router_Route</classname> es la ruta
  7. standard del framework. Combina la facilidad de uso con la flexibilidad
  8. para la definición de rutas. Cada ruta consiste fundamentalmente en el
  9. mapeo de la URL (de partes estáticas y dinámicas (variables)) y puede ser
  10. iniciada con valores predeterminados así como con requisitos variables.
  11. </para>
  12. <para>
  13. Imaginemos que nuestra aplicación ficticia necesitará algunas páginas
  14. informativas sobre los autores del contenido.
  15. Queremos ser capaces de apuntar nuestro navegador web a
  16. <code>http://domain.com/author/martel</code> para ver la información
  17. sobre este muchacho "martel". La ruta para esa funcionalidad podría
  18. parecerse a:
  19. </para>
  20. <programlisting role="php"><![CDATA[
  21. $route = new Zend_Controller_Router_Route(
  22. 'author/:username',
  23. array(
  24. 'controller' => 'profile',
  25. 'action' => 'userinfo'
  26. )
  27. );
  28. $router->addRoute('user', $route);
  29. ]]></programlisting>
  30. <para>
  31. El primer parámetro en el constructor
  32. <classname>Zend_Controller_Router_Route</classname>
  33. es una definición de ruta que será acompañada de una URL.
  34. Las definiciones de ruta consisten en partes estáticas y dinámicas
  35. separadas por el caracter barra ('/'). Las partes estáticas son simples
  36. textos: <code>author</code>. Las partes dinámicas, llamadas variables,
  37. se marcan anteponiendo dos puntos (:) al nombre de la variable
  38. <code>:username</code>.
  39. </para>
  40. <note>
  41. <title>Uso de Caracteres</title>
  42. <para>
  43. La implementación actual le permite utilizar cualquier carácter
  44. (salvo una barra) como un identificador de variable, pero se recomienda
  45. encarecidamente que se utilicen sólo caracteres que sean válidos para
  46. identificadores de variables PHP. En implementaciones futuras se
  47. podría alterar este comportamiento, resultando en probables fallos
  48. escondidos en su código.
  49. </para>
  50. </note>
  51. <para>
  52. Este ejemplo de ruta debería ser coincidente cuando apunta su navegador a
  53. <code>http://domain.com/author/martel</code>, en cuyo caso todas sus
  54. variables se inyectan al objeto <classname>Zend_Controller_Request</classname>
  55. y quedando accesibles en <code>ProfileController</code>.
  56. Las variables devueltas por este ejemplo pueden ser representadas como
  57. el siguiente array de pares clave/valor:
  58. </para>
  59. <programlisting role="php"><![CDATA[
  60. $values = array(
  61. 'username' => 'martel',
  62. 'controller' => 'profile',
  63. 'action' => 'userinfo'
  64. );
  65. ]]></programlisting>
  66. <para>
  67. Después, <classname>Zend_Controller_Dispatcher_Standard</classname>
  68. debe invocar al método <code>userinfoAction()</code> de su clase
  69. <code>ProfileController</code> (en el módulo por defecto) basado en
  70. estos valores. Allí se podrán acceder a todas las variables mediante
  71. los métodos <classname>Zend_Controller_Action::_getParam()</classname>
  72. o <classname>Zend_Controller_Request::getParam()</classname>:
  73. </para>
  74. <programlisting role="php"><![CDATA[
  75. public function userinfoAction()
  76. {
  77. $request = $this->getRequest();
  78. $username = $request->getParam('username');
  79. $username = $this->_getParam('username');
  80. }
  81. ]]></programlisting>
  82. <para>
  83. La definición de ruta puede contener uno o más caracteres especiales
  84. - un comodín - representado por el símbolo '*'.
  85. Se utiliza para reunir parámetros al igual que el valor de ruta por
  86. defecto del Módulo (var => pares de valores definidos en la URI).
  87. La siguiente ruta imita más o menos el comportamiento de la ruta del
  88. Módulo:
  89. </para>
  90. <programlisting role="php"><![CDATA[
  91. $route = new Zend_Controller_Router_Route(
  92. ':module/:controller/:action/*',
  93. array('module' => 'default')
  94. );
  95. $router->addRoute('default', $route);
  96. ]]></programlisting>
  97. <sect4 id="zend.controller.router.routes.standard.variable-defaults">
  98. <title>Variables por Defecto</title>
  99. <para>
  100. Cada variable en la ruta puede tener una valor por defecto y para
  101. esto es que se usa el segundo parámetro del constructor
  102. <classname>Zend_Controller_Router_Route</classname>.
  103. Este parámetro es un array con claves representando los nombres de
  104. variables y con valores como los deseados por defecto:
  105. </para>
  106. <programlisting role="php"><![CDATA[
  107. $route = new Zend_Controller_Router_Route(
  108. 'archive/:year',
  109. array('year' => 2006)
  110. );
  111. $router->addRoute('archive', $route);
  112. ]]></programlisting>
  113. <para>
  114. La ruta de arriba comparará URLs como
  115. <code>http://domain.com/archive/2005</code> y
  116. <code>http://example.com/archive</code>. En este último caso la
  117. variable year(año) tendrá un valor inicial predeterminado de 2006.
  118. </para>
  119. <para>
  120. Este ejemplo resultará en inyectar una variable año al objeto
  121. solicitud. Ya que no hay información de enrutamiento presente
  122. (no se define ningún controlador ni parámetros de acción),
  123. la solicitud será enviada al controlador y al método de acción
  124. por defecto (que a la vez ambos están definidos en
  125. <classname>Zend_Controller_Dispatcher_Abstract</classname>).
  126. Para hacerlos más utilizables, tiene que proporcionar un controlador
  127. válido y una acción válida como la ruta por defecto:
  128. </para>
  129. <programlisting role="php"><![CDATA[
  130. $route = new Zend_Controller_Router_Route(
  131. 'archive/:year',
  132. array(
  133. 'year' => 2006,
  134. 'controller' => 'archive',
  135. 'action' => 'show'
  136. )
  137. );
  138. $router->addRoute('archive', $route);
  139. ]]></programlisting>
  140. <para>
  141. Entonces, esta ruta resultará en el dispatch al método
  142. <code>showAction()</code> de la clase
  143. <code>ArchiveController</code>.
  144. </para>
  145. </sect4>
  146. <sect4 id="zend.controller.router.routes.standard.variable-requirements">
  147. <title>Requerimientos para Variables</title>
  148. <para>
  149. Podemos agregar un tercer parámetro al constructor
  150. <classname>Zend_Controller_Router_Route</classname> donde podemos
  151. establecer los requisitos para las variables.
  152. Estas son definidas como partes de una expresión regular:
  153. </para>
  154. <programlisting role="php"><![CDATA[
  155. $route = new Zend_Controller_Router_Route(
  156. 'archive/:year',
  157. array(
  158. 'year' => 2006,
  159. 'controller' => 'archive',
  160. 'action' => 'show'
  161. ),
  162. array('year' => '\d+')
  163. );
  164. $router->addRoute('archive', $route);
  165. ]]></programlisting>
  166. <para>
  167. Con una ruta definida como la de arriba, el router comparará solo
  168. cuando la variable año contenga datos numéricos, eg.
  169. <code>http://domain.com/archive/2345</code>. Una URL como
  170. <code>http://example.com/archive/test</code> no se comparará y en su
  171. lugar el control se pasará a la próxima ruta en la cadena.
  172. </para>
  173. </sect4>
  174. <sect4 id="zend.controller.router.routes.standard.translated-segments">
  175. <title>Segmentos Traducidos</title>
  176. <para>
  177. El standard de ruta brinda apoyo a la traducción de segmentos.
  178. Para utilizar esta característica, tiene que definir por lo menos
  179. un traductor (una instancia de <classname>Zend_Translate</classname>)
  180. mediante una de las siguientes formas:
  181. </para>
  182. <itemizedlist>
  183. <listitem>
  184. <para>
  185. Ponerlo en el registro con la clave
  186. <classname>Zend_Translate</classname>.
  187. </para>
  188. </listitem>
  189. <listitem>
  190. <para>
  191. Setearlo mediante el método estático
  192. <classname>Zend_Controller_Router_Route::setDefaultTranslator()</classname>.
  193. </para>
  194. </listitem>
  195. <listitem>
  196. <para>
  197. Pasarlo como cuarto parámetro al constructor.
  198. </para>
  199. </listitem>
  200. </itemizedlist>
  201. <para>
  202. Por defecto, se utilizará el "locale" especificado en la instancia
  203. <classname>Zend_Translate</classname>.
  204. Para anularlo, debe setearlo (como una instancia de
  205. <classname>Zend_Locale</classname> o un string local) de una de las
  206. siguientes maneras:
  207. </para>
  208. <itemizedlist>
  209. <listitem>
  210. <para>
  211. Ponerlo en el registro con la clave <classname>Zend_Locale</classname>.
  212. </para>
  213. </listitem>
  214. <listitem>
  215. <para>
  216. Setearlo mediante el método estático
  217. <classname>Zend_Controller_Router_Route::setDefaultLocale()</classname>.
  218. </para>
  219. </listitem>
  220. <listitem>
  221. <para>
  222. Pasarlo como cuarto parámetro al constructor.
  223. </para>
  224. </listitem>
  225. <listitem>
  226. <para>
  227. Pasarlo como parámetro <code>@locale</code> al método de
  228. ensamblaje.
  229. </para>
  230. </listitem>
  231. </itemizedlist>
  232. <para>
  233. Los segmentos traducidos se dividen en dos partes.
  234. Los segmentos fijos están precedidos por un único signo
  235. <code>@</code>, y serán traducidos al "locale" actual para el
  236. ensamblaje y se revierten al ID del mensaje cuando se acepte
  237. nuevamente. Los segmentos dinámicos tienen el prefijo <code>:@</code>.
  238. Para el ensamblaje, el parámetro dado será traducido y se insertará
  239. en la posición del parámetro.
  240. Cuando se acepte, el parámetro traducido de la URL volverá al ID
  241. del mensaje nuevamente.
  242. </para>
  243. <note>
  244. <title>IDs de Mensajes y Archivos de Lenguajes Separados</title>
  245. <para>
  246. Ocasionalmente un ID de mensaje que quiere usar en una de sus
  247. rutas ya se utiliza en un view script o en otro lugar.
  248. Para tener pleno control sobre URLs seguras, debe usar
  249. un archivo de idioma separado para los mensajes utilizados en
  250. la ruta.
  251. </para>
  252. </note>
  253. <para>
  254. La siguiente es la forma más sencilla para preparar el itinerario
  255. normal para el uso de la traducción del segmento:
  256. </para>
  257. <programlisting role="php"><![CDATA[
  258. // Prepare el traductor
  259. $translator = new Zend_Translate('array', array(), 'en');
  260. $translator->addTranslation(array('archive' => 'archiv',
  261. 'year' => 'jahr',
  262. 'month' => 'monat',
  263. 'index' => 'uebersicht'),
  264. 'de');
  265. // Establecer el "locale" actual para el traductor
  266. $translator->setLocale('en');
  267. // Establecerlo como traductor por defecto para las rutas
  268. Zend_Controller_Router_Route::setDefaultTranslator($translator);
  269. ]]></programlisting>
  270. <para>
  271. Este ejemplo demuestra el uso de segmentos estáticos:
  272. </para>
  273. <programlisting role="php"><![CDATA[
  274. // Crear la ruta
  275. $route = new Zend_Controller_Router_Route(
  276. '@archive',
  277. array(
  278. 'controller' => 'archive',
  279. 'action' => 'index'
  280. )
  281. );
  282. $router->addRoute('archive', $route);
  283. // Ensamblar la URL en el locale actual por defecto: archive
  284. $route->assemble(array());
  285. // Ensamblar la URL en alemán: archiv
  286. $route->assemble(array());
  287. ]]></programlisting>
  288. <para>
  289. Puede usar segmentos dinámicos para crear veriones traducidas como
  290. del tipo módulo-ruta:
  291. </para>
  292. <programlisting role="php"><![CDATA[
  293. // Crear la ruta
  294. $route = new Zend_Controller_Router_Route(
  295. ':@controller/:@action/*',
  296. array(
  297. 'controller' => 'index',
  298. 'action' => 'index'
  299. )
  300. );
  301. $router->addRoute('archive', $route);
  302. // Ensamblar la URL en el "locale" por defecto: archive/index/foo/bar
  303. $route->assemble(array('controller' => 'archive', 'foo' => 'bar'));
  304. // Ensamblar la URL en alemán: archiv/uebersicht/foo/bar
  305. $route->assemble(array('controller' => 'archive', 'foo' => 'bar'));
  306. ]]></programlisting>
  307. <para>
  308. También puede mezclar segmentos estáticos y dinámicos:
  309. </para>
  310. <programlisting role="php"><![CDATA[
  311. // Crear la ruta
  312. $route = new Zend_Controller_Router_Route(
  313. '@archive/:@mode/:value',
  314. array(
  315. 'mode' => 'year'
  316. 'value' => 2005,
  317. 'controller' => 'archive',
  318. 'action' => 'show'
  319. ),
  320. array('mode' => '(month|year)'
  321. 'value' => '\d+')
  322. );
  323. $router->addRoute('archive', $route);
  324. // Ensamblar la URL en el "locale" por defecto: archive/month/5
  325. $route->assemble(array('mode' => 'month', 'value' => '5'));
  326. // Ensamblar la URL en alemán: archiv/monat/5
  327. $route->assemble(array('mode' => 'month', 'value' => '5', '@locale' => 'de'));
  328. ]]></programlisting>
  329. </sect4>
  330. </sect3>
  331. <!--
  332. vim:se ts=4 sw=4 et:
  333. -->