Zend_Mail-Encoding.xml 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.mail.encoding">
  5. <title>エンコーディング</title>
  6. <para>
  7. テキストおよび <acronym>HTML</acronym> メッセージの本文は、デフォルトでは
  8. quotedprintable 方式でエンコードされます。
  9. メッセージヘッダーもbase64を <methodname>setHeaderEncoding()</methodname> で指定しなければ
  10. quotedprintable 方式でエンコードされます。
  11. もしあなたがラテン文字ベースではない言語を使う場合、 base64 がより適切でしょう。
  12. その他の添付ファイルは、デフォルトでは
  13. base64 でエンコードされますが、<methodname>addAttachment()</methodname> のコール時に変更したり
  14. <acronym>MIME</acronym> パートオブジェクトに後から代入して変更することもできます。
  15. 7Bit エンコーディングおよび 8Bit エンコーディングは、
  16. 現在はバイナリデータにのみ適用可能です。
  17. </para>
  18. <para>
  19. ヘッダ、特に subject のエンコーディングは、油断のならない話題です。
  20. <classname>Zend_Mime</classname> は現在、quoted printable ヘッダを
  21. RFC-2045 にもとづいてエンコードするアルゴリズムを自前で実装しています。
  22. <methodname>iconv_mime_encode</methodname> および <methodname>mb_encode_mimeheader</methodname>
  23. には、特定の文字セットにおける問題があるからです。
  24. このアルゴリズムではヘッダを空白文字でのみ区切るので、
  25. 推奨される長さである 76 文字を超えるヘッダができてしまう可能性があります。
  26. そんな場合は、次の例と同様にヘッダのエンコード方式を
  27. BASE64 に変更しましょう。
  28. </para>
  29. <programlisting language="php"><![CDATA[
  30. // デフォルトは Zend_Mime::ENCODING_QUOTEDPRINTABLE です
  31. $mail = new Zend_Mail('KOI8-R');
  32. // KOI8-R で表現されるロシア語はラテン文字ベースの言語と
  33. // 大きく異なるので、Base64 エンコーディングに変更します
  34. $mail->setHeaderEncoding(Zend_Mime::ENCODING_BASE64);
  35. ]]></programlisting>
  36. <para>
  37. <classname>Zend_Mail_Transport_Smtp</classname> は、行頭がドット 1 文字あるいはドット
  38. 2 文字の場合にその行をエンコードします。これにより、
  39. SMTP プロトコルに違反するメールを作成しないようにします。
  40. </para>
  41. </sect1>
  42. <!--
  43. vim:se ts=4 sw=4 et:
  44. -->