Zend_Controller-Router-Route-Static.xml 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.router.routes.static">
  5. <title>Zend_Controller_Router_Route_Static</title>
  6. <para>
  7. Die oben angeführten Beispiele verwenden alle dynamische Routen -- Routen die einem Pattern
  8. entsprechen. Trotzdem wird manchmal eine spezielle Route in Stein gegossen, und das Starten
  9. der Regular Expression Maschine wäre ein Overkill. Die Lösung zu dieser Situation ist die
  10. Verwendung von statischen Routen:
  11. </para>
  12. <programlisting language="php"><![CDATA[
  13. $route = new Zend_Controller_Router_Route_Static(
  14. 'login',
  15. array('controller' => 'auth', 'action' => 'login')
  16. );
  17. $router->addRoute('login', $route);
  18. ]]></programlisting>
  19. <para>
  20. Die obige Route passt zu einer <acronym>URL</acronym> von
  21. <filename>http://domain.com/login</filename>, und leitet weiter zu
  22. <methodname>AuthController::loginAction()</methodname>.
  23. </para>
  24. <note id="zend.controller.router.routes.static.warning">
  25. <title>Warnung: Statische Routen müssen vernüftige Standards enthalten</title>
  26. <para>
  27. Da eine statische Route keinen Teil der <acronym>URL</acronym> an das Requestobjekt als
  28. Parameter übergibt, <emphasis>muss</emphasis> man alle Parameter die für das Bearbeiten
  29. eines Requests notwendig sind als Standards an die Route übergeben. Das unterdrücken der
  30. Standardwerte von "controller" oder "action" kann zu unerwarteten Ergebnissen führen,
  31. und wird dazu führen das der Request nicht bearbeitet werden kann.
  32. </para>
  33. <para>
  34. Als Daumenregel sollte man immer jeden der folgenden Standardwerte anbieten:
  35. </para>
  36. <itemizedlist>
  37. <listitem><para>controller</para></listitem>
  38. <listitem><para>action</para></listitem>
  39. <listitem><para>module (if not default)</para></listitem>
  40. </itemizedlist>
  41. <para>
  42. Optional kann auch der "useDefaultControllerAlways" Parameter an den Frontcontroller
  43. während des Bootstrappings übergeben werden:
  44. </para>
  45. <programlisting language="php"><![CDATA[
  46. $front->setParam('useDefaultControllerAlways', true);
  47. ]]></programlisting>
  48. <para>
  49. Trotzdem ist das als Workaround anzusehen; es ist immer besser vernünftige Standards
  50. explizit zu definieren.
  51. </para>
  52. </note>
  53. </sect3>
  54. <!--
  55. vim:se ts=4 sw=4 et:
  56. -->