Zend_Controller-Router-Route.xml 14 KB

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