
セキュリティ動向チェック
Security&Trustウォッチ(38)
偽装メールを見破れ!(前編)
上野宣
2006/3/29
国会という公の場を使って1通のメールの真偽が問われたのは記憶に新しい。前回のコラム「メールは信頼できても信用できない」でも取り上げたとおり、普通のメールを本物だ、偽物だと証明することは非常に難しい。ましてや国会で取り上げられたような黒塗りのメール文面だけでは技術的に真偽を問うことは困難だ。
プリントアウトされた黒塗りメールの真偽を見分けるのは難しいが、普段受信しているメールならば偽装メールを見破ることもできる。手元に届けられた普通のメールを例にして読み解いていこう。
■メールは1つのテキストデータでできている
あなたがOutlookなどのメールクライアントで読んでいるメールは、実際には「メールメッセージ」と呼ばれるテキストデータが整形されたうえで表示されているものである。文章以外に画像やアプリケーションなどの添付ファイルが付いていたとしても、元のメールメッセージはただのテキストで構成されている。そのテキストを、メールクライアントが解釈して、個別のデータに分解したりバイナリファイルなどに変換したりしている。
メールメッセージは大きく分けて「ヘッダ」と「ボディ」で構成されている。ヘッダには、送信者(From)やあて先(To)、件名(Subject)などの付随情報が含まれている。ボディにはいわゆるメール本文となるテキストや、テキストに変換されたバイナリデータが含まれている。この2つは空行(CR+LF)で分けられている。
![]() |
| 図1 メールメッセージの構成 |
メールメッセージについて解説したものは多いので、詳細はほかの文献などに譲る。ここでは偽装を見破るポイントを学んでいこう。
■見破るポイントはヘッダにあり
前段でメールメッセージの構造の概要について説明した理由は、偽装を見破るポイントがヘッダに含まれているからだ。まずは、ヘッダについての最低限の仕組みを知っておこう。
ヘッダは、ヘッダフィールドと呼ばれる情報で構成されている。これは、「To」や「Subject」、「Received」などで始まる情報であり、メールがサーバを経由するごとに追加されていく仕組みになっている。
図2を見ながら説明すると、最初のヘッダ(1)は送信者のメールクライアントが作成したものである。送信後は、基本的にSMTPサーバと呼ばれるサーバを経由するごとに、新たなヘッダが既存のヘッダの上に追加されている(2)〜(4)。例外として、受信者側のPOPサーバやメールクライアントが付けるヘッダがあるが、これは既存のヘッダの下に追加されることが多い(5)。
![]() |
| 図2 ヘッダ情報(画像をクリックすると別ウインドウで拡大します) 1:送信者側のメールクライアントが付けたヘッダ 2:送信者側のSMTPサーバが付けたヘッダ 3:受信者側のSMTPサーバが受信した際に付けたヘッダ 4:受信者側のSMTPサーバがローカルに転送する際に付けたヘッダ 5:受信者側のPOPサーバが付けたヘッダ |
■偽のヘッダは簡単に付けられる
ヘッダを偽装することがどれぐらい簡単なのかを知っておこう。最も手軽に偽装できるヘッダフィールドは、差出人を表す「From」だ。多くのメールクライアントでは、「From」に指定する内容を、差出人の「名前」と「メールアドレス」という項目で任意に設定できる。つまり、ウソの内容も入力可能ということだ。
実際に自分のメールクライアントの「名前」と「メールアドレス」の設定を適当に書き換えて、自分あてにメールを送ってみるといい。受信したメールの差出人は先ほど適当に書き換えた内容になっているはずだ(一部の環境では送信できない場合もある)。
■最初のヘッダは書き換え放題
これ以外にも図2の(1)に入るヘッダは差出人側のメールクライアントが作成するので、差出人が自由に書き換えられる項目が多い。ただし、「Content-Type」など一部の項目は、メールを正常に表示するために適当に書き換えるわけにはいかないものもある。
不思議に思うかもしれないが、あて先に当たる「To」や「Cc」といった項目も自由に書くことが可能である。メールの仕組みでは、あて先に書いてあるメールアドレスには送信せず、まったく関係のないメールアドレスに送信するといったこともできる。
これは「Bcc」を使ってメールを送信した場合を考えると分かりやすい。試しに自分あてに「Bcc」を使ってメールを送信して、その受信メールのヘッダを見てほしい。「Bcc」というヘッダフィールドは載っていないはずである。
メールの送信を担うSMTPサーバにとっては、メールメッセージ内のヘッダの差出人やあて先部分に何が書かれていようが関係がないのだ。実際にどのように送信しているかということに興味があるならば、SMTPというプロトコルのエンベロープという仕組みについて調べるとよい。
■最初のSMTPサーバは相手側の手の中にある
送信者側のSMTPサーバが付けるヘッダも送信者側が偽装できる可能性が高いヘッダである(図2の(2))。
ISPなどが用意しているSMTPサーバを使う場合には、ヘッダをサーバ上で自由に改変することはできないが、送信用のSMTPサーバを自前で用意すれば、自由に書き換えることができるようになってしまう。
この中で特に偽装メールで書き換えられやすいのは、1番目の「Received」ヘッダフィールドである。その理由は、ここに送信側、受信側のSMTPサーバのドメイン名やIPアドレス、メールを受け取った時間といった情報が含まれているためである。これらはメールの発信元を特定する重要な情報として扱われるのだ。
偽装者は、先に述べた方法で差出人を表す「From」の項を書き換えただけでは信ぴょう性に乏しいので、「Received」の項も合わせて偽装することで信ぴょう性を少しでも上げるのだ。少しばかりメールに詳しい人ならば一番下の「Received」の項目だけを確認し、「このメールは正しい」と誤認してしまうかもしれない。
■偽の「Received」ヘッダフィールドを付けるには
偽装メールを送信できてしまうポイントは、最初のヘッダが自由に書き換え放題だというところにある。差出人のメールクライアントが作成する図2の(1)の部分に、偽の「Received」も含めてしまえばいい。
偽装者が(1)〜(3)までの情報をヘッダフィールドに含めておく。経由するSMTPサーバでは、偽装されたヘッダの上に新たなヘッダを追加していくことになる。一見すると偽装した「Received」も本物のように見えるというわけだ。なお、実際に送る手順は紹介しない。
メールのヘッダという情報の偽装が簡単だということが少しお分かりいただけたかと思う。もちろん、最後に紹介した方法で送った偽装メールでも見破ることができる。その見破る方法や疑われにくいメールを送る方法は、次回のコラムで紹介する。
と、ここで終わってしまうと猜疑心ばかり残ってしまうので、メールのヘッダの中で比較的信頼できる情報のことも少し触れておく。
比較的信頼できる情報とは、受信者側のSMTPサーバが付けた情報である。図2でいうと(3)〜(4)のヘッダである。これは受信者側の環境なので、送信者側が自由にすることはできない。多くのメールメッセージでも、上から1つ目か2つ目までの「Received」ヘッダフィールドは受信者側のSMTPサーバが付けたものである。
| メールクライアントでヘッダを見てみよう 皆さんが使っているメールクライアントでは、普段はヘッダ情報の一部しか表示されていないだろう。例えば、Outlook Expressでメールを開いてみると、送信者やあて先、件名しか表示されていない。
ヘッダ情報をOutlook Expressで見るには、メニューから[ファイル]>[プロパティ]>[詳細]とたどる。
メールメッセージ全体を見るには、さらに[メッセージのソース]ボタンを押す。
Webメールでもヘッダを表示できるものもある。Googleが提供するGmailを使っているならば、メールを開いて[詳細オプション]を開き、[オリジナルを表示]をクリックすると、メールメッセージのソースが表示される。
|
| Profile |
| 上野 宣(うえの せん) 1975年京都生まれ。情報セキュリティを世に広げるべく、講演や執筆活動とさまざまな方面で活動中。近著に「今夜わかるメールプロトコル」、「今夜わかるTCP/IP」、「今夜わかるHTTP」(共に翔泳社)がある。 |
| Security&Trust記事一覧 |
ホワイトペーパー(TechTargetジャパン)
- この脆弱性対策エンジンは“永遠に完成しない” (2010/3/9)
パターンファイルに頼らず防御する「要の技術」は、いまも完成にはいたっていない。その理由とは―― - Gumblarがあぶり出す 「空虚なセキュリティ対策」 (2010/3/1)
ガンブラーの脅威は、組織の構造や外部委託問題をあぶり出します。そのセキュリティ対策、建前論になっていませんか? - 決済アプリのセキュリティ基準、PA-DSSとは (2010/2/24)
“ペイメントアプリケーション”のセキュリティ基準を定めたPA-DSS。厳密に定められた14の要件を、PCI DSSと対比させつつ解説します - 「鍵は“J”の中にあるよ」CTF by ダークナイト解答編 (2010/2/22)
ダークナイトからの挑戦状、いかがだっただろうか。WiresharkにNetworkMiner、WinRARを駆使し、“J”に隠された秘密を解き明かせ!
|
|
スキルアップ/キャリアアップ(JOB@IT)
スポンサーからのお知らせ
- - PR -
| 「いつかは壊れるサーバ」そんな故障に 迅速で安価に手軽に対応する方法とは? New! |
| 「特権ユーザー」の事件を防げ! 万能権限を持つユーザーの管理方法とは? New! |
| 仮想環境の構築とデータ保護の特効薬?! 実績と信頼性の高いパッケージで安心運用 |
| 仮想環境のバックアップもこれまでどおり 「まるごと取ってまるごと戻す」簡単運用 |
| おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |
| その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |
| 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |
| 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |
- - PR -
お勧め求人情報

**先週の人気講座ランキング**
〜CCNA編〜
| ◆ | TomcatやJBossなどAPサーバ環境に関する 情報を集約! “業務”用APサーバ大百科 New! |
| ◆ | 一気に解説! 最新のクラスタストレージ 「RAIDを超えたストレージ基準」……など New! |
| ◆ | クラウド的ユーザー体験の変化は脅威か? 仮想化技術を使いこなす運用管理術を紹介 New! |

| ◆ | 上司や部下、部署内メンバーとの情報共有 を“ガラッ”と変えるコラボツールとは? New! |
| ◆ | おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| ◆ | 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |

| ◆ | Twitterのアカウントはなぜ突破された? メールによる新手の攻撃手法とその対策 |
| ◆ | もう仮想化のお試しフェイズは終わりだ! Hyper-V 2.0が基幹システムも仮想化 |
| ◆ | 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |

| ◆ | クライアント企業から求められる人材 ⇒IT技術と経営戦略を併せ持つ「戦略家」 |
| ◆ | .NET編集長が実践する「技術情報検索術」 サンプル・コードを簡単に探す“技”は? |
| ◆ | 業務効率と情報セキュリティ対策を両立! 手間なく確実に機密情報を守る方法とは? |

| ◆ | 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| ◆ | 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |

| ◆ | 【CTC事例】約30の基幹システムを統合! 膨大なバッジジョブを制御した方法は? |
| ◆ | 仮想化すればコストは削減できるか? 仮想化に必要な「3つの視点」を解説する |
| ◆ | その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |













