Zend_Log-Writers-Mail.xml 7.0 KB

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