2
0

Zend_Controller-Router-Route-Chain.xml 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15780 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.router.routes.chain">
  5. <title>Zend_Controller_Router_Route_Chain</title>
  6. <para>
  7. <classname>Zend_Controller_Router_Route_Chain</classname> ist eine Route die es erlaubt
  8. mehrere Routen miteinander zu verketten. Das erlaubt es Hostname-Routen und Pfad-Routen zu
  9. verketten, oder zum Beispiel mehrere Pfad-Routen. Verkettung kann entweder
  10. program-technisch oder mit einer Konfigurationsdatei durchgeführt werden.
  11. </para>
  12. <note>
  13. <title>Priorität der Parameter</title>
  14. <para>
  15. Wenn Routen wie die Hostnameroute und die Pfadroute zusammengekettet werden, haben die
  16. Parameter der Hostnameroute eine höhere Priorität als die Parameter der Pfadroute.
  17. Deshalb wird, wenn man im Hostnamen und in der Pfadroute einen Kontroller definiert,
  18. der Kontroller der Hostnameroute ausgewählt.
  19. </para>
  20. </note>
  21. <para>
  22. Wenn Programmtechnisch verkettet wird, gibt es zwei Wege das zu tun. Der erste besteht
  23. darin eine neue Instanz von <classname>Zend_Controller_Router_Route_Chain</classname> zu
  24. erstellen und dann die <code>chain</code> Methode mehrere Male mit allen Routen aufzurufen
  25. die zusammen verkettet werden sollen. Der andere Weg besteht darin die erste Route zu
  26. nehmen, z.B. eine Hostname Route, und die <code>chain</code> Methode mit der Route auf Ihr
  27. aufzurufen, die angehängt werden soll. Das verändert die Hostname Route nicht, gibt aber
  28. eine neue Instanz von <classname>Zend_Controller_Router_Route_Chain</classname> zurück, die
  29. dann beide Routen verkettet hat:
  30. </para>
  31. <programlisting language="php"><![CDATA[
  32. // Erstellung zweier Routen
  33. $hostnameRoute = new Zend_Controller_Router_Route_Hostname(...);
  34. $pathRoute = new Zend_Controller_Router_Route(...);
  35. // Erster Weg, mit Verkettung über die Chain Route
  36. $chainedRoute = new Zend_Controller_Router_Route_Chain();
  37. $chainedRoute->chain($hostnameRoute)
  38. ->chain($pathRoute);
  39. // Zweiter Weg, direkt verketten
  40. $chainedRoute = $hostnameRoute->chain($pathRoute);
  41. ]]></programlisting>
  42. <para>
  43. Wenn Routen miteinander verkettet werden, ist Ihr standardmäßiges Trennzeichen ein
  44. Schrägstrich. Es kann Fälle geben in denen man ein anderes Trennzeichen verwenden will:
  45. </para>
  46. <programlisting language="php"><![CDATA[
  47. // Zwei Routen erstellen
  48. $firstRoute = new Zend_Controller_Router_Route('foo');
  49. $secondRoute = new Zend_Controller_Router_Route('bar');
  50. // Sie mit einem anderen Trennzeichen miteinander verketten
  51. $chainedRoute = $firstRoute->chain($secondRoute, '-');
  52. // Zusammenbauen der Route: "foo-bar"
  53. echo $chainedRoute->assemble();
  54. ]]></programlisting>
  55. <sect4 id="zend.controller.router.routes.chain.config">
  56. <title>Verkettete Routen über Zend_Config</title>
  57. <para>
  58. Um Routen in einer Config Datei miteinander zu verketten gibt es zusätzliche Parameter
  59. für die Konfiguration von Ihnen. Der einfachere Weg ist die Verwendung des
  60. <code>chains</code> Parameters. Dieser ist einfach eine Liste von Routen, die mit der
  61. Eltern-Route verkettet werden. Weder die Eltern-, noch die Kind-Routen werden dem
  62. Router direkt hinzugefügt sondern nur die resultierende verkettete Route. Der Name der
  63. verketteten Route im Router ist der Name der Eltern-Route und der Name der Kind-Route
  64. verbunden mit einem Bindestrich (-). Eine einfache Konfiguration würde in XML wie folgt
  65. aussehen:
  66. </para>
  67. <programlisting language="xml"><![CDATA[
  68. <routes>
  69. <www type="Zend_Controller_Router_Route_Hostname">
  70. <route>www.example.com</route>
  71. <chains>
  72. <language type="Zend_Controller_Router_Route">
  73. <route>:language</route>
  74. <reqs language="[a-z]{2}">
  75. <chains>
  76. <index type="Zend_Controller_Router_Route_Static">
  77. <route></route>
  78. <defaults module="default" controller="index" action="index" />
  79. </index>
  80. <imprint type="Zend_Controller_Router_Route_Static">
  81. <route>imprint</route>
  82. <defaults module="default" controller="index" action="index" />
  83. </imprint>
  84. </chains>
  85. </language>
  86. </chains>
  87. </www>
  88. <users type="Zend_Controller_Router_Route_Hostname">
  89. <route>users.example.com</route>
  90. <chains>
  91. <profile type="Zend_Controller_Router_Route">
  92. <route>:username</route>
  93. <defaults module="users" controller="profile" action="index" />
  94. </profile>
  95. </chains>
  96. </users>
  97. <misc type="Zend_Controller_Router_Route_Static">
  98. <route>misc</route>
  99. </misc>
  100. </routes>
  101. ]]></programlisting>
  102. <para>
  103. Das führt zu den drei Routen <code>www-language-index</code>,
  104. <code>www-language-imprint</code> und <code>users-language-profile</code> die nur
  105. basierend auf dem Hostnamen und der Route <code>misc</code> passen, was wiederum mit
  106. jedem Hostnamen passt.
  107. </para>
  108. <para>
  109. Der alternative Weg der Erstellung einer verketteten Route ist der über den
  110. <code>chain</code> Parameter, was wiederum nur mit dem Chain-Route Typ direkt
  111. verwendet werden kann, und auch im Root Level funktioniert:
  112. </para>
  113. <programlisting language="xml"><![CDATA[
  114. <routes>
  115. <www type="Zend_Controller_Router_Route_Chain">
  116. <route>www.example.com</route>
  117. </www>
  118. <language type="Zend_Controller_Router_Route">
  119. <route>:language</route>
  120. <reqs language="[a-z]{2}">
  121. </language>
  122. <index type="Zend_Controller_Router_Route_Static">
  123. <route></route>
  124. <defaults module="default" controller="index" action="index" />
  125. </index>
  126. <imprint type="Zend_Controller_Router_Route_Static">
  127. <route>imprint</route>
  128. <defaults module="default" controller="index" action="index" />
  129. </imprint>
  130. <www-index type="Zend_Controller_Router_Route_Chain">
  131. <chain>www, language, index</chain>
  132. </www-index>
  133. <www-imprint type="Zend_Controller_Router_Route_Chain">
  134. <chain>www, language, imprint</chain>
  135. </www-imprint>
  136. </routes>
  137. ]]></programlisting>
  138. <para>
  139. Man kann auch den <code>chain</code> Parameter als Array übergeben statt die Routen
  140. mit einem Komma zu seperieren:
  141. </para>
  142. <programlisting language="xml"><![CDATA[
  143. <routes>
  144. <www-index type="Zend_Controller_Router_Route_Chain">
  145. <chain>www</chain>
  146. <chain>language</chain>
  147. <chain>index</chain>
  148. </www-index>
  149. <www-imprint type="Zend_Controller_Router_Route_Chain">
  150. <chain>www</chain>
  151. <chain>language</chain>
  152. <chain>imprint</chain>
  153. </www-imprint>
  154. </routes>
  155. ]]></programlisting>
  156. </sect4>
  157. </sect3>
  158. <!--
  159. vim:se ts=4 sw=4 et:
  160. -->