Zend_Mail-Encoding.xml 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.mail.encoding">
  5. <title>Kodierung</title>
  6. <para>
  7. Text und <acronym>HTML</acronym> Nachrichten werden standardmäßig mit dem "quotedprintable"
  8. Mechanismus kodiert. Nachrichten Header werden auch mit dem quotedprintable Mechanismus
  9. kodiert wenn in <methodname>setHeaderEncoding()</methodname> nicht base64 spezifiziert
  10. wurde. Wenn man eine Sprache verwendet die nicht auf römischen Buchstaben basiert, ist
  11. base64 besser geeignet. Alle anderen Anhänge werden über "base64" kodiert, wenn an den
  12. <acronym>MIME</acronym> Teil keine andere Kodierung über den
  13. <methodname>addAttachment()</methodname> Aufruf übergeben oder später zugewiesen worden ist.
  14. 7Bit und 8Bit Kodierung können derzeit nur auf binärische Inhalte angewandt werden.
  15. </para>
  16. <para>
  17. Die Kodierung des Headers, speziell die Kodierung des Subjects ist ein trickreiches Thema.
  18. <classname>Zend_Mime</classname> implementiert aktuell seinen eigenen Algorithmus um
  19. quotedprintable Header nach RFC-2045 zu kodieren. Der Hintergrund ist das
  20. Problem von <methodname>iconv_mime_encode()</methodname> und
  21. <methodname>mb_encode_mimeheader()</methodname> in Bezug zu bestimmten Zeichensätzen. Dieser
  22. Algorithmus unterbricht den Header nur bei Leerzeichen, das zu Headern führen könnte welche
  23. die erwartete Länge von 76 Zeichen weit überschreiten. Für diesen Fall wird vorgeschlagen
  24. zur BASE64 Header Kodierung zu wechseln, wie im folgenden Beispiel beschrieben:
  25. </para>
  26. <programlisting language="php"><![CDATA[
  27. // Standardmäßig Zend_Mime::ENCODING_QUOTEDPRINTABLE
  28. $mail = new Zend_Mail('KOI8-R');
  29. // Auf Base64 Kodierung zurücksetzen da russisch ausgedrückt in KOI8-R zu
  30. // Römisch basierten Buchstaben sehr unterschiedlich ist
  31. $mail->setHeaderEncoding(Zend_Mime::ENCODING_BASE64);
  32. ]]></programlisting>
  33. <para>
  34. <classname>Zend_Mail_Transport_Smtp</classname> kodiert die Zeilen beginnend mit einem oder
  35. zwei Punkten, so dass die Mail das SMTP Protokoll nicht missachtet.
  36. </para>
  37. </sect1>