skillup

技術ブログ

サーバー・ネットワーク

メール送信に関して その2 メールメッセージのデータ形式

投稿日:

前回に引き続き、メールのメッセージ構造について書きたいと思います。

大まかな構造

メールメッセージの基本的な形式はRFC5322で規定され、大まかに分けるとヘッダ部とボディ部に分かれます。(今回添付ファイルが付いたケースは別とします。)

ヘッダ部

ヘッダ部はさらに下記のような要素に分かれます。

メールアドレス

読んで字のごとくです。

From/Sender/Reply-To

Fromはメッセージ作成者、Senderは送信者です。同一の場合、Senderは不必要です。

To/Cc/Bcc

そのままのいみです。厳密にいうとToと送信先が違うケースもありますが、ここでは省略します。

Date

メッセージの送信時刻です。

Message-Id/In-Reply-To/References

Message-Idはメッセージをユニークに識別する記号です。In-Reply-Toはメッセージに返信する際に付加されます。Referencesも近い概念ですが、直接の返信元だけでなく、返信を繰り返すたびに追加されていきます。

Subject

件名です。

ボディ部

こちらはメールの本文の情報になります。ボディ部も通常はASCII文字だけで構成されます。Unicode以前はASCII文字だけで構成されているISO-2022-JPというエンコーディングがあります。日本語だけで送る場合は今でもISO-2022-JPで送ることがい一般的です。

MIME

ASCII文字だけの場合は件名に日本語や送信者を記述できませんでしたし、バイナリデータを送ることもできませんでした。MIME規格が生まれたことで件名に日本語とバイナリデータを添付させることができるようになりました。

ヘッダ中の非ASCII文字

MIMEではASCII文字にエンコードすることでヘッダ中に非ASCII文字を入れることができます。=?UTF-8?B?5pel5・・などの文字はこのエンコーディングされた文字列を表しています。ただし、処理自体は複雑なため、技術者中瀬です。(私もこれで苦労したことが結構あります。)

Content-Transfer-Encoding

次はボディ部の変換になります。ISO-2022-JP以外はいずれも8bitデータであったり、テキストデータでないこともあるため、これらを変換するためにBase64とQuoted-Printableという規格が使われます。(ここではBase64のみに触れます。)

Base64

バイナリデータをテキストに変換します。Content-Transfer-Encoding:base64と指定します。

Content-Type

type/subjectの形式でボディ部のデータの種類を表します。


text/plain US-ASCIIテキスト
text/html HTMLテキスト
text/jpeg JPEG画像
など

8bitデータの扱い

SMTPは基本的に7bitのデータしか扱えませんが、拡張で8bitデータを扱うこともできます。

文字化け対策

メールが文字化けをする場合、下記のようなことが原因であることが多いです。

charasetが正しくない

テキストがsjisなのにContent-TypeにISO-2022-JPが含まれているなど。

charasetに含まれない文字を使用している

例えば半角カナ、〇囲み、カッコつき漢字など・

MIMEエンコーディング

=?UTF-8?B?5pel5・・の部分がダブルクオートでくくられていたりするとエンコーディングが正常に行われません。

参考リンク

SoftWareDesign 9月号
http://www.atmarkit.co.jp/ait/articles/0602/18/news009.html
http://i.loveruby.net/ja/projects/tmail/doc/basics.html
http://d.hatena.ne.jp/takami_hiroki/20110209/p1
http://e-mail.pc-beginner.net/mail/html_mail.html

-サーバー・ネットワーク
-

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

vimの基本的な使い方 設定ファイル、基本コマンド他

もう4年ぐらいの付き合いになる憎らしくもかわいいエディタvi(vim)について。 雑誌に特集があったのでこれを機にまとめてみました。シリーズものになるかも・・・ Contents1 Vi(vim)とは …

no image

SSH鍵認証について+CakePHP2でのセッション切れ

鍵認証の設定をしたのでその際のメモなどを。 Contents1 SSH鍵認証2 CakePHP2セッション切れ SSH鍵認証 サーバーで公開鍵・秘密鍵を作成 サーバーで公開鍵を登録 クライアント側で秘 …

no image

セッションとクッキーについて

セッションとクッキーについての違いを整理しておこうと思います。 Contents1 そもそものHTTPプロトコルについて2 ステートフルな状態を実現するために2.1 方法1 クライアント側で情報を保持 …

no image

firewall復習 ansibleコマンドもかねて

CentOS7ではファイアーウォールの設定をfirewallというコマンドで行います。要はportのブロックですね。 以前下記リンクでもfirewallについて書いたんですが、あまり理解もできていなか …

no image

任意のログファイルのログローテションについて

本日は自作のログファイルをうまくローテーションさせる方法について。 自作でログを作っておりますと、日がたつにずれどんどんと容量が膨らんでいきます。 放置するととんでもない量になっていることが多いですね …