Zend_Controller-Router-Route.xml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15156 -->
  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> ist die standardmäßige Framework Route. Sie kombiniert einfache
  8. Verwendung mit einer flexiblen Routendefinition. Jede Route besteht primär aus URL Übereinstimmungen
  9. (von statischen und dynamischen Teilen (Variablen)) und kann mit Standardwerten initialisiert werden
  10. wie auch mit variablen Notwendigkeiten.
  11. </para>
  12. <para>
  13. Angenommen unsere fiktive Anwendung benötigt eine informelle Seite über den Seitenauthor. Es soll möglich
  14. sein mit dem Browser auf <code>http://domain.com/author/martel</code> zu verweisen um die Informationen über
  15. diesen "martel" Typ zu sehen. Und die Route für so eine Funktionalität würde so aussehen:
  16. </para>
  17. <programlisting role="php"><![CDATA[
  18. $route = new Zend_Controller_Router_Route(
  19. 'author/:username',
  20. array(
  21. 'controller' => 'profile',
  22. 'action' => 'userinfo'
  23. )
  24. );
  25. $router->addRoute('user', $route);
  26. ]]></programlisting>
  27. <para>
  28. Der ersten Parameter im Konstruktor von <code>http://domain.com/author/martel</code> ist eine
  29. Routendefinition die einer URL entspricht. Routendefinitionen bestehen aus statischen und dynamischen
  30. Teilen die durch einen Schrägstrich ('/') seperiert sind. Statische Teile sind nur einfacher Text:
  31. <code>author</code>. Dynamische Teile, Variablen genannt, werden durch einen vorangestellten
  32. Doppelpunkt, zum variablen Namen, markiert: <code>:username</code>.
  33. </para>
  34. <note>
  35. <title>Zeichen verwenden</title>
  36. <para>
  37. Die aktuelle Implementation erlaubt die Verwendung von allen Zeichen (außer einem Schrägstrich) als
  38. variablen Identifikator, aber es wird dringend empfohlen das nur Zeichen verwendet werden die auch für
  39. PHP Veriablen Identifikatoren gültig sind. Zukünftige Implementationen können dieses Verhlaten ändern,
  40. was zu versteckten Bugs im eigenen Code führen würde.
  41. </para>
  42. </note>
  43. <para>
  44. Diese Beispielroute wird verglichen wenn der Browser auf <code>http://domain.com/author/martel</code>
  45. zeigt. In diesem Fall werden alle seine Variablen dem <classname>Zend_Controller_Request</classname> Objekt
  46. injiziiert und es kann im <code>ProfileController</code> darauf zugegriffen werden. Variablen die von diesem
  47. Beispiel zurückgegeben werden können als Array mit den folgenden Schlüssel- und Wertepaaren repräsentiert
  48. werden:
  49. </para>
  50. <programlisting role="php"><![CDATA[
  51. $values = array(
  52. 'username' => 'martel',
  53. 'controller' => 'profile',
  54. 'action' => 'userinfo'
  55. );
  56. ]]></programlisting>
  57. <para>
  58. Später sollte <classname>Zend_Controller_Dispatcher_Standard</classname> die <code>userinfoAction()</code> Methode
  59. der eigenen <code>ProfileController</code> Klasse aufrufen (im Standardmodul) basierend auf diesen
  60. Werten. Dort ist es möglich alle Variablen durch die <classname>Zend_Controller_Action::_getParam()</classname>
  61. oder <classname>Zend_Controller_Request::getParam()</classname> Methoden zuzugreifen:
  62. </para>
  63. <programlisting role="php"><![CDATA[
  64. public function userinfoAction()
  65. {
  66. $request = $this->getRequest();
  67. $username = $request->getParam('username');
  68. $username = $this->_getParam('username');
  69. }
  70. ]]></programlisting>
  71. <para>
  72. Eine Routendefinition kann ein weiteres spezielles Zeichen enthalten - eine Wildcard - dargestellt durch ein
  73. '*' Symbol. Es wird verwendet um Parameter genauso wie im standard Modulrouter zu erhalten (var => Wertepaare
  74. definiert in der URI). Die folgende Route imitiert mehr oder weniger das Verhalten des Modulrouters:
  75. </para>
  76. <programlisting role="php"><![CDATA[
  77. $route = new Zend_Controller_Router_Route(
  78. ':module/:controller/:action/*',
  79. array('module' => 'default')
  80. );
  81. $router->addRoute('default', $route);
  82. ]]></programlisting>
  83. <sect4 id="zend.controller.router.routes.standard.variable-defaults">
  84. <title>Variable Standards</title>
  85. <para>
  86. Jede Variable im Router kann einen Standardwert haben und das ist für was der zweite Parameter des
  87. Konstruktors von <classname>Zend_Controller_Router_Route</classname> verwendet wird. Dieser Parameter ist ein
  88. Array mit Schlüsseln die Variablennamen repräsentieren und mit Werten als gewünschte Standards:
  89. </para>
  90. <programlisting role="php"><![CDATA[
  91. $route = new Zend_Controller_Router_Route(
  92. 'archive/:year',
  93. array('year' => 2006)
  94. );
  95. $router->addRoute('archive', $route);
  96. ]]></programlisting>
  97. <para>
  98. Die obige Route entspricht URLs wie <code>http://domain.com/archive/2005</code> und
  99. <code>http://example.com/archive</code>. Im späteren Fall wird die Variable year einen initialen
  100. Standardwert von 2006 haben.
  101. </para>
  102. <para>
  103. Dieses Beispiel resultiert darin das eine year Variable in das Anfrage Objekt injiziiert wird. Da keine
  104. Routinginformation vorhanden ist (es sind keine Kontroller und Aktionsparameter definiert), wird die
  105. Anwendung zum Standardkontroller und der Aktionsmethode (welche beide in
  106. <classname>Zend_Controller_Dispatcher_Abstract</classname> definiert sind) weitergeleitet. Um es verwendbarer
  107. zu machen muß ein gültiger Kontroller und eine gültige aktion als Standard für die Route angegeben
  108. werden:
  109. </para>
  110. <programlisting role="php"><![CDATA[
  111. $route = new Zend_Controller_Router_Route(
  112. 'archive/:year',
  113. array(
  114. 'year' => 2006,
  115. 'controller' => 'archive',
  116. 'action' => 'show'
  117. )
  118. );
  119. $router->addRoute('archive', $route);
  120. ]]></programlisting>
  121. <para>
  122. Diese Route führt dazu das an die Methode <code>showAction()</code> der Klasse
  123. <code>ArchiveController</code> weitergeleitet wird.
  124. </para>
  125. </sect4>
  126. <sect4 id="zend.controller.router.routes.standard.variable-requirements">
  127. <title>Variable Anforderungen</title>
  128. <para>
  129. Man kann einen dritten Parameter dem <classname>Zend_Controller_Router_Route</classname> Konstruktor hinzufügen
  130. wo variable Anforderungen gesetzt werden können. Diese werden als Teil eines regulären Ausdrucks
  131. definiert:
  132. </para>
  133. <programlisting role="php"><![CDATA[
  134. $route = new Zend_Controller_Router_Route(
  135. 'archive/:year',
  136. array(
  137. 'year' => 2006,
  138. 'controller' => 'archive',
  139. 'action' => 'show'
  140. ),
  141. array('year' => '\d+')
  142. );
  143. $router->addRoute('archive', $route);
  144. ]]></programlisting>
  145. <para>
  146. Mit einer Route die wie oben definiert ist, wird das Routing nur dann stattfinden wenn die year
  147. Variable nummerische Daten enthält, z.B. <code>http://domain.com/archive/2345</code>.
  148. Eine URL wie <code>http://example.com/archive/test</code> wird nicht zugeordnet und die Kontrolle wird
  149. stattdessen an die nächste Route in der Kette übertragen.
  150. </para>
  151. </sect4>
  152. <sect4 id="zend.controller.router.routes.standard.translated-segments">
  153. <title>Übersetzte Segmente</title>
  154. <para>
  155. Die Standardroute unterstützt übersetzte Segmente. Um dieses Feature zu verwenden muß zumindest
  156. ein Übersetzer (eine Instanz von <classname>Zend_Translate</classname>) auf einem der folgenden Wege
  157. definiert werden:
  158. </para>
  159. <itemizedlist>
  160. <listitem>
  161. <para>
  162. In die Registry mit dem Schlüssel <classname>Zend_Translate</classname> geben.
  163. </para>
  164. </listitem>
  165. <listitem>
  166. <para>
  167. Über die statische Methode
  168. <classname>Zend_Controller_Router_Route::setDefaultTranslator()</classname> setzen.
  169. </para>
  170. </listitem>
  171. <listitem>
  172. <para>
  173. Als vierten Parameter im Constructor übergeben.
  174. </para>
  175. </listitem>
  176. </itemizedlist>
  177. <para>
  178. Standardmäßig wird das Gebietsschema verwendet das in der Instanz von <classname>Zend_Translate</classname>
  179. verwendet wird. Um es zu überschreiben, kann es (als Instanz von <classname>Zend_Locale</classname> oder
  180. einem Gebietsschema-String) auf einem der folgenden Wege gesetzt werden:
  181. </para>
  182. <itemizedlist>
  183. <listitem>
  184. <para>
  185. In die Registry mit dem Schlüssel <classname>Zend_Locale</classname> geben.
  186. </para>
  187. </listitem>
  188. <listitem>
  189. <para>
  190. Über die statische Methode
  191. <classname>Zend_Controller_Router_Route::setDefaultLocale()</classname> setzen.
  192. </para>
  193. </listitem>
  194. <listitem>
  195. <para>
  196. Als fünften Parameter im Constructor übergeben.
  197. </para>
  198. </listitem>
  199. <listitem>
  200. <para>
  201. Als <code>@locale</code> Parameter der assemble Methode übergeben.
  202. </para>
  203. </listitem>
  204. </itemizedlist>
  205. <para>
  206. Übersetzte Segmente werden in zwei Teile getrennt. Ein fixes Segment dem ein einzelnes
  207. <code>@</code>-Zeichen vorangestellt wird, der anhand des aktuellen Gebietsschemas übersetzt wird
  208. und auf der Position des Parameters eingefügt wird. Dynamischen Segmenten wird ein
  209. <code>:@</code> vorangestellt. Beim Zusammenbauen, wird der gegebene Parameter übersetzt und an der
  210. Position des Parameters eingefügt. Bei der Überprüfung, wird der übersetzte Parameter von der
  211. URL wieder in die Nachrichten ID umgewandelt.
  212. </para>
  213. <note>
  214. <title>Nachrichten IDs und eigene Sprachdateien</title>
  215. <para>
  216. Normalerweise werden Nachrichten IDs die man in einer seiner Routen verwenden will, bereits in
  217. einem View Skript oder irgendwo anders verwendet. Um die komplette Kontrolle über sichere
  218. URLs zu haben, sollte man eine eigene Sprachdatei für die Nachrichten haben die in einer
  219. Route verwendet werden.
  220. </para>
  221. </note>
  222. <para>
  223. Nachfolgend ist die einfachste Verwendung gezeigt um eine Standardroute für übersetzte Segmente
  224. zu Verwenden:
  225. </para>
  226. <programlisting role="php"><![CDATA[
  227. // Den Übersetzer vorbereiten
  228. $translator = new Zend_Translate('array', array(), 'en');
  229. $translator->addTranslation(array('archive' => 'archiv',
  230. 'year' => 'jahr',
  231. 'month' => 'monat',
  232. 'index' => 'uebersicht'),
  233. 'de');
  234. // Das aktuelle Gebietsschema für den Übersetzer setzen
  235. $translator->setLocale('en');
  236. // Als Standard-Übersetzer für Routen setzen
  237. Zend_Controller_Router_Route::setDefaultTranslator($translator);
  238. ]]></programlisting>
  239. <para>
  240. Dieses Beispiel zeigt die Verwendung von statischen Segmenten:
  241. </para>
  242. <programlisting role="php"><![CDATA[
  243. // Die Route erstellen
  244. $route = new Zend_Controller_Router_Route(
  245. '@archive',
  246. array(
  247. 'controller' => 'archive',
  248. 'action' => 'index'
  249. )
  250. );
  251. $router->addRoute('archive', $route);
  252. // Die URL im Standard-Gebietsschema zusammenbauen: archive
  253. $route->assemble(array());
  254. // Die URL in Deutsch zusammenbauen: archiv
  255. $route->assemble(array());
  256. ]]></programlisting>
  257. <para>
  258. Man kann dynamische Segmente verwenden um eine Modul-Route, so wie die übersetzte Version,
  259. zu erstellen:
  260. </para>
  261. <programlisting role="php"><![CDATA[
  262. // Die Route erstellen
  263. $route = new Zend_Controller_Router_Route(
  264. ':@controller/:@action/*',
  265. array(
  266. 'controller' => 'index',
  267. 'action' => 'index'
  268. )
  269. );
  270. $router->addRoute('archive', $route);
  271. // Die URL im Standard-Gebietsschema zusammenbauen: archive/index/foo/bar
  272. $route->assemble(array('controller' => 'archive', 'foo' => 'bar'));
  273. // Die URL in Deutsch zusammenbauen: archiv/uebersicht/foo/bar
  274. $route->assemble(array('controller' => 'archive', 'foo' => 'bar'));
  275. ]]></programlisting>
  276. <para>
  277. Man kann auch statische und dynamische Segmente mischen:
  278. </para>
  279. <programlisting role="php"><![CDATA[
  280. // Die Route erstellen
  281. +$route = new Zend_Controller_Router_Route(
  282. '@archive/:@mode/:value',
  283. array(
  284. 'mode' => 'year'
  285. 'value' => 2005,
  286. 'controller' => 'archive',
  287. 'action' => 'show'
  288. ),
  289. array('mode' => '(month|year)'
  290. 'value' => '\d+')
  291. );
  292. $router->addRoute('archive', $route);
  293. // Die URL im Standard-Gebietsschema zusammenbauen: archive/month/5
  294. $route->assemble(array('mode' => 'month', 'value' => '5'));
  295. // Die URL in Deutsch zusammenbauen: archiv/monat/5
  296. $route->assemble(array('mode' => 'month', 'value' => '5', '@locale' => 'de'));
  297. ]]></programlisting>
  298. </sect4>
  299. </sect3>
  300. <!--
  301. vim:se ts=4 sw=4 et:
  302. -->