Zend_Controller-Plugins-ErrorHandler.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15103 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.plugins.standard.errorhandler">
  5. <title>Zend_Controller_Plugin_ErrorHandler</title>
  6. <para>
  7. <classname>Zend_Controller_Plugin_ErrorHandler</classname> bietet ein Plugin für die Handhabung von Ausnahmen
  8. die von der Anwendung geworfen werden, inklusive denen die aus fehlenden Kontrollern oder Aktionen
  9. resultieren; das ist eine Alternative zu den Methoden die in der
  10. <link linkend="zend.controller.exceptions">Sektion MVC Ausnahmen</link> aufgeführt sind.
  11. </para>
  12. <para>
  13. Die primären Ziele dieses Plugins sind:
  14. </para>
  15. <itemizedlist>
  16. <listitem>
  17. <para>Abfangen von Ausnahmen die durch fehlende Kontroller oder Aktionsmethoden auftreten</para>
  18. </listitem>
  19. <listitem>
  20. <para>Abfangen von Ausnahmen die innerhalb von Kontrollern aufrufen</para>
  21. </listitem>
  22. </itemizedlist>
  23. <para>
  24. Mit anderen Worten ist das <code>ErrorHandler</code> Plugin kreiert worden um HTTP 404 Fehler zu
  25. behandeln (fehlende Seite) und 500 Fehler (interner Fehler). Es ist nicht dazu gedacht Ausnahmen
  26. zu fangen die in anderen Plugins oder durch das Routen verursacht werden.
  27. </para>
  28. <para>
  29. Standardmäßig leitet <classname>Zend_Controller_Plugin_ErrorHandler</classname> auf
  30. <code>ErrorController::errorAction()</code> im Standardmodul weiter. Es kann ein alternativer Wert für dieses
  31. gesetzt werden durch Verwendung der diversen Zugriffsmethoden die zu dem Pligin existieren:
  32. </para>
  33. <itemizedlist>
  34. <listitem>
  35. <para>
  36. <code>setErrorHandlerModule()</code> setzt das Kontroller Modul das verwendet werden soll.
  37. </para>
  38. </listitem>
  39. <listitem>
  40. <para>
  41. <code>setErrorHandlerController()</code> setzt den Kontroller der verwendet werden soll.
  42. </para>
  43. </listitem>
  44. <listitem>
  45. <para>
  46. <code>setErrorHandlerAction()</code> setzt die Kontroller Aktion die verwendet werden soll.
  47. </para>
  48. </listitem>
  49. <listitem>
  50. <para>
  51. <code>setErrorHandler()</code> nimmt ein assoziatives Array, welches einen der Schlüssel
  52. 'module', 'controller', oder 'action' enthalten kann und mit denen es die gewünschten Werte setzt.
  53. </para>
  54. </listitem>
  55. </itemizedlist>
  56. <para>
  57. Zusätzlich kann ein optionales assoziatives Array an den Konstruktor übergeben werden, welches dann an den
  58. <code>setErrorHandler()</code> weitergeleitet wird.
  59. </para>
  60. <para>
  61. <classname>Zend_Controller_Plugin_ErrorHandler</classname> benötigt einen <code>postDispatch()</code> Hook und
  62. prüft auf Ausnahmen die im <link linkend="zend.controller.response">Antwort Objekt</link> registriert
  63. sind. Wenn welche gefunden werden, versucht es zur registrieren Fehler Handler Aktion weiterzuleiten.
  64. </para>
  65. <para>
  66. Wenn eine Ausnahme wärend der Abarbeitung des Error Handlers auftritt, teilt das Plugin dem Front Kontroller
  67. mit das eine Ausnahme geworfen werden muß, und die letzte registrierte Ausnahme im Antwort Objekt wird
  68. nocheinmal geworfen.
  69. </para>
  70. <sect4 id="zend.controller.plugins.standard.errorhandler.fourohfour">
  71. <title>Den Fehler Handler als 404 Handler verwenden</title>
  72. <para>
  73. Da das <code>ErrorHandler</code> Plugin nicht nur Anwendungsfehler erfasst, sondern auch Fehler in der
  74. Kontroller Kette die durch fehlende Kontroller Klassen und/oder Aktions Methoden auftreten, kann es
  75. als 404 Handler verwendet werden. Hierfür muß der eigene Fehler Kontroller den Typ der Ausnahme prüfen.
  76. </para>
  77. <para>
  78. Aufgefangene Ausnahmen werden in einem in der Anfrage registrierten Objekt geloggt. Um dieses zu
  79. empfangen kann <classname>Zend_Controller_Action::_getParam('error_handler')</classname> verwendet werden:
  80. </para>
  81. <programlisting role="php"><![CDATA[class ErrorController extends Zend_Controller_Action
  82. {
  83. public function errorAction()
  84. {
  85. $errors = $this->_getParam('error_handler');
  86. }
  87. }
  88. ]]>
  89. </programlisting>
  90. <para>
  91. Sobald das Fehler Objekt vorhanden ist, kann man es über den Typ mit <code>$errors->type</code>
  92. erhalten. Es wird eines der folgenden sein:
  93. </para>
  94. <itemizedlist>
  95. <listitem>
  96. <para>
  97. <classname>Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_CONTROLLER</classname>,
  98. zeigt das der Kontroller nicht gefunden wurde.
  99. </para>
  100. </listitem>
  101. <listitem>
  102. <para>
  103. <classname>Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_ACTION</classname>,
  104. zeigt das die angefragte Aktion nicht gefunden wurde.
  105. </para>
  106. </listitem>
  107. <listitem>
  108. <para>
  109. <classname>Zend_Controller_Plugin_ErrorHandler::EXCEPTION_OTHER</classname>,
  110. zeigt andere Ausnahmen.
  111. </para>
  112. </listitem>
  113. </itemizedlist>
  114. <para>
  115. Man kann auf eine der ersten Typen testen, und wenn dem so ist, eine 404 Seite anzeigen:
  116. </para>
  117. <programlisting role="php"><![CDATA[
  118. class ErrorController extends Zend_Controller_Action
  119. {
  120. public function errorAction()
  121. {
  122. $errors = $this->_getParam('error_handler');
  123. switch ($errors->type) {
  124. case Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_CONTROLLER:
  125. case Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_ACTION:
  126. // 404 Fehler -- Kontroller oder Aktion nicht gefunden
  127. $this->getResponse()
  128. ->setRawHeader('HTTP/1.1 404 Not Found');
  129. // ... Ausgabe für die Anzeige erzeugen...
  130. break;
  131. default:
  132. // Anwendungsfehler; Fehler Seite anzeigen, aber den
  133. // Status Code nicht ändern
  134. break;
  135. }
  136. }
  137. }
  138. ]]>
  139. </programlisting>
  140. <para>
  141. Letztendlich kann die Anwendung die den Fehler Handler verursacht hat, empfangen werden indem die
  142. <code>exception</code> Eigenschaft des <code>error_handler</code> Objektes genommen wird:
  143. </para>
  144. <programlisting role="php"><![CDATA[
  145. public function errorAction()
  146. {
  147. $errors = $this->_getParam('error_handler');
  148. switch ($errors->type) {
  149. case Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_CONTROLLER:
  150. case Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_ACTION:
  151. // 404 Fehler -- Kontroller oder Aktion nicht gefunden
  152. $this->getResponse()
  153. ->setRawHeader('HTTP/1.1 404 Not Found');
  154. // ... Ausgabe für die Anzeige erzeugen...
  155. break;
  156. default:
  157. // Anwendungsfehler; Fehler Seite anzeigen, aber den
  158. // Status Code nicht ändern
  159. // ...
  160. // Ausnahme loggen:
  161. $exception = $errors->exception;
  162. $log = new Zend_Log(
  163. new Zend_Log_Writer_Stream(
  164. '/tmp/applicationException.log'
  165. )
  166. );
  167. $log->debug($exception->getMessage() . "\n" .
  168. $exception->getTraceAsString());
  169. break;
  170. }
  171. }
  172. ]]>
  173. </programlisting>
  174. </sect4>
  175. <sect4 id="zend.controller.plugins.standard.errorhandler.buffer">
  176. <title>Zuvor gerenderte Ausgaben erhalten</title>
  177. <para>
  178. Wenn mehrfache Aktionen in einer Anfrage behandelt werden, oder wenn die Aktion mehrere Aufrufe zu
  179. <code>render()</code> macht, ist es möglich das das Antwort Objekt bereits Inhalt in sich gespeichert
  180. hat. Das kann dazu führen das eine Mixtur vin erwartetem Inhalt und Fehler Inhalt gerendert wird.
  181. </para>
  182. <para>
  183. Wenn Fehler innerhalb solcher Seiten gerendert werden, ist keine Änderung notwendig. Wenn solche
  184. Inhalte nicht gerendert werden sollen, muß der Antwort Body vor dem rendern jeglicher Views
  185. gelöscht werden:
  186. </para>
  187. <programlisting role="php"><![CDATA[
  188. $this->getResponse()->clearBody();
  189. ]]>
  190. </programlisting>
  191. </sect4>
  192. <sect4 id="zend.controller.plugins.standard.errorhandler.examples">
  193. <title>Beispiele für die Verwendung des Plugins</title>
  194. <example id="zend.controller.plugins.standard.errorhandler.examples.example-1">
  195. <title>Standardverwendung</title>
  196. <programlisting role="php"><![CDATA[
  197. $front = Zend_Controller_Front::getInstance();
  198. $front->registerPlugin(new Zend_Controller_Plugin_ErrorHandler());
  199. ]]>
  200. </programlisting>
  201. </example>
  202. <example id="zend.controller.plugins.standard.errorhandler.examples.example-2">
  203. <title>Einen anderen Fehler Handler setzen</title>
  204. <programlisting role="php"><![CDATA[
  205. $front = Zend_Controller_Front::getInstance();
  206. $front->registerPlugin(new Zend_Controller_Plugin_ErrorHandler(array(
  207. 'module' => 'mystuff',
  208. 'controller' => 'static',
  209. 'action' => 'error'
  210. )));
  211. ]]>
  212. </programlisting>
  213. </example>
  214. <example id="zend.controller.plugins.standard.errorhandler.examples.example-3">
  215. <title>Zugriffsmethoden verwenden</title>
  216. <programlisting role="php"><![CDATA[
  217. $plugin = new Zend_Controller_Plugin_ErrorHandler();
  218. $plugin->setErrorHandlerModule('mystuff')
  219. ->setErrorHandlerController('static')
  220. ->setErrorHandlerAction('error');
  221. $front = Zend_Controller_Front::getInstance();
  222. $front->registerPlugin($plugin);
  223. ]]>
  224. </programlisting>
  225. </example>
  226. </sect4>
  227. <sect4 id="zend.controller.plugins.standard.errorhandler.controllerexamples">
  228. <title>Beispiel für den Fehler Kontroller</title>
  229. <para>
  230. Um das Fehler Handler Plugin zu verwenden, benötigt man einen Fehler Kontroller. Nachfolgend ist ein
  231. einfaches Beispiel.
  232. </para>
  233. <programlisting role="php"><![CDATA[
  234. class ErrorController extends Zend_Controller_Action
  235. {
  236. public function errorAction()
  237. {
  238. $errors = $this->_getParam('error_handler');
  239. switch ($errors->type) {
  240. case Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_CONTROLLER:
  241. case Zend_Controller_Plugin_ErrorHandler::EXCEPTION_NO_ACTION:
  242. // 404 Fehler -- Kontroller oder Aktion nicht gefunden
  243. $this->getResponse()->setRawHeader('HTTP/1.1 404 Not Found');
  244. $content =<<<EOH
  245. <h1>Error!</h1>
  246. <p>Die angefragte Seite konnte nicht gefunden werden.</p>
  247. EOH;
  248. break;
  249. default:
  250. // Anwendungsfehler
  251. $content =<<<EOH
  252. <h1>Fehler!</h1>
  253. <p>Ein unerwarteter Fehler trat auf.
  254. Bitte versuchen Sie es etwas später nocheinmal.</p>
  255. EOH;
  256. break;
  257. }
  258. // Vorherige Inhalte löschen
  259. $this->getResponse()->clearBody();
  260. $this->view->content = $content;
  261. }
  262. }
  263. ]]>
  264. </programlisting>
  265. </sect4>
  266. </sect3>
  267. <!--
  268. vim:se ts=4 sw=4 et:
  269. -->