Zend_Log-Writers-Mail.xml 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15215 -->
  3. <!-- Reviewed: no -->
  4. <sect2 id="zend.log.writers.mail">
  5. <title>In Emails schreiben</title>
  6. <para>
  7. <classname>Zend_Log_Writer_Mail</classname> schreibt Logeinträge in eine Email Nachricht indem es
  8. <classname>Zend_Mail</classname> verwendet. Der Konstruktor von <classname>Zend_Log_Writer_Mail</classname>
  9. nimmt ein <classname>Zend_Mail</classname> Objekt und ein optionales <classname>Zend_Layout</classname>
  10. Objekt entgegen.
  11. </para>
  12. <para>
  13. Der primäre Verwendungszweck für <classname>Zend_Log_Writer_Mail</classname> ist es Entwickler,
  14. System Administratoren, oder jede benötigte Partei über Fehler zu benachrichtigen die
  15. mit PHP-basierenden Skripten auftreten können. <classname>Zend_Log_Writer_Mail</classname> wurde
  16. aus der Idee geboren das, wenn irgendetwas fehlschlägt, ein Mensch sofort darüber
  17. alarmiert werden muß um korrigierende Maßnahmen durchzuführen.
  18. </para>
  19. <para>
  20. Die grundsätzliche Verwendung wird anbei gezeigt:
  21. </para>
  22. <programlisting role="php"><![CDATA[
  23. $mail = new Zend_Mail();
  24. $mail->setFrom('errors@example.org')
  25. ->addTo('project_developers@example.org');
  26. $writer = new Zend_Log_Writer_Mail($mail);
  27. // Setzt den Subjekt-Text der verwendet wird; Zusammenfassung der Anzahl der
  28. // Fehler wird der Subjektzeile angefügt bevor die Nachricht gesendet wird.
  29. $writer->setSubjectPrependText('Errors with script foo.php');
  30. // Nur Einträge vom Level Warnung und höher schicken
  31. $writer->addFilter(Zend_Log::WARN);
  32. $log = new Zend_Log();
  33. $log->addWriter($writer);
  34. // Irgendetwas schlechtes findet statt!
  35. $log->error('Kann nicht zur datenbank verbinden');
  36. // Wenn der Writer heruntergefahren wird, wird Zend_Mail::send()
  37. // getriggert um ein Email mit allen Logeinträgen zu senden die
  38. // auf oder über dem Filterlevel von Zend_Log liegen
  39. ]]></programlisting>
  40. <para>
  41. <classname>Zend_Log_Writer_Mail</classname> stellt den Email Body standardmäßig
  42. als reinen Text dar.
  43. </para>
  44. <para>
  45. Es wird eine Email gesendet die alle Logeinträge enthält die auf oder
  46. über dem Filterlevel sind. Wenn zum Beispiel, Einträge mit Warnungs-Level
  47. gesendet werden sollen, und zwei Warnungen und fünf Fehler stattfinden,
  48. wird das Email in Summe sieben Logeinträge enthalten.
  49. </para>
  50. <sect3 id="zend.log.writers.mail.layoutusage">
  51. <title>Zend_Layout Verwendung</title>
  52. <para>
  53. Eine <classname>Zend_Layout</classname> Instanz kann verwendet werden um den HTML
  54. Anteil einer Multipart Email zu erstellen. Wenn eine <classname>Zend_Layout</classname>
  55. Instanz in Verwendung ist, nimmt <classname>Zend_Log_Writer_Mail</classname> an das sie
  56. verwendet wird um HTML darzustellen und setzt den Body HTML für die
  57. Nachricht als den <classname>Zend_Layout</classname>-darstellenden Wert.
  58. </para>
  59. <para>
  60. Wenn <classname>Zend_Log_Writer_Mail</classname> mit einer <classname>Zend_Layout</classname>
  61. Instanz verwendet wird, hat man die Option eine eigene Formatierung zu
  62. setzen indem die <code>setLayoutFormatter()</code> Methode verwendet wird.
  63. Wenn kein <classname>Zend_Layout</classname>-spezifischer formatierungs-Eintrag
  64. spezifiziert wurde, wird der aktuell in Verwendung befindliche Formatierer
  65. verwendet. Die vollständige Verwendung von <classname>Zend_Layout</classname> mit
  66. einem eigenen Formatierer wird anbei gezeigt.
  67. </para>
  68. <programlisting role="php"><![CDATA[
  69. $mail = new Zend_Mail();
  70. $mail->setFrom('errors@example.org')
  71. ->addTo('project_developers@example.org');
  72. // Beachte das die Subjektzeile nicht auf der Zend_Mail
  73. // Instanz gesetzt wird!
  74. // Verwende eine einfache Zend_Layout Instanz mit seinen Standardwerten
  75. $layout = new Zend_Layout();
  76. // Erstelle einen Formatierer der den Eintrag in ein Listitem Tag umhüllt
  77. $layoutFormatter = new Zend_Log_Formatter_Simple(
  78. '<li>' . Zend_Layout::DEFAULT_FORMAT . '</li>'
  79. );
  80. $writer = new Zend_Log_Writer_Mail($mail, $layout);
  81. // Füge den Formatierer für die Einträge hinzu die mit Zend_Layout
  82. // dargestellt werden
  83. $writer->setLayoutFormatter($layoutFormatter);
  84. $writer->setSubjectPrependText('Fehler im Skript foo.php');
  85. $writer->addFilter(Zend_Log::WARN);
  86. $log = new Zend_Log();
  87. $log->addWriter($writer);
  88. // Irgendetwas schlechtes hat stattgefunden!
  89. $log->error('unable to connect to database');
  90. // Wenn der Writer heruntergefahren wird, wird Zend_Mail::send()
  91. // getriggert um ein Email mit allen Logeinträgen zu senden die
  92. // auf oder über dem Filterlevel von Zend_Log liegen
  93. ]]></programlisting>
  94. </sect3>
  95. <sect3 id="zend.log.writers.mail.dynamicsubjectline">
  96. <title>Zusammenfassung der Fehlerlevel in der Subjektzeile</title>
  97. <para>
  98. Die <code>setSubjectPrependText()</code> Methode kann statt
  99. <classname>Zend_Mail::setSubject()</classname> verwendet werden um die Subjektzeile
  100. dynamisch zu schreiben bevor die Email gesendet wird. Wenn, zum Beispiel,
  101. der dem Subjekt vorangestellte Text "Fehler des Skriptes" heißt, würde das
  102. Subjekt des Emails das von <classname>Zend_Log_Writer_Mail</classname> mit zwei Warnungen
  103. und fünf Fehlern erstellt wird "Fehler des Skriptes (warn = 2; error = 5)" sein.
  104. Wenn kein Subjekttext mit <classname>Zend_Log_Writer_Mail</classname> vorangestellt wird,
  105. wird die <classname>Zend_Mail</classname> Subjektzeile verwendet, wenn vorhanden.
  106. </para>
  107. </sect3>
  108. <sect3 id="zend.log.writers.mail.caveats">
  109. <title>Vorbehalte</title>
  110. <para>
  111. Das Senden von Logeinträgen über Emails kann gefährlich sein. Wenn Fehlerzustände
  112. vom eigenen Skript falsch behandelt werden, oder man die Fehlerlevel falsch verwendet,
  113. kann man sich selbst in einer Situation finden in der man Hunderte oder Tausende von
  114. Emails zu den Empfängern sendet abhängig von der Frequenz der eigenen Fehler.
  115. </para>
  116. <para>
  117. Bis dato bietet <classname>Zend_Log_Writer_Mail</classname> keinen Mechanismus für die
  118. Limitierung oder andernfalls die Dosierung der Nachrichten. Solche Funktionalitäten,
  119. können vom Konsumenten, wenn benötigt, selbst implementiert werden.
  120. </para>
  121. <para>
  122. Nochmals, <classname>Zend_Log_Writer_Mail</classname>'s primäres Ziel ist es proaktiv Menschen
  123. über Fehlerzustände zu benachrichtigen. Wenn diese Fehler zeitgerecht behandelt werden,
  124. und Sicherheitsmaßnahmen platziert werden um diese Vorbehalte in Zukunft zu
  125. verhindern, dann kann die Email-basierende Benachtichtigung von Fehlern ein
  126. nützliches Tool sein.
  127. </para>
  128. </sect3>
  129. </sect2>
  130. <!--
  131. vim:se ts=4 sw=4 et:
  132. -->