web-dev-qa-db-ja.com

電子メールに画像を埋め込む方法

電子メールに画像を埋め込む必要があります。どうすればいいのですか?

私はサードパーティのツールを使いたくありませんし、言語固有の答えにも興味がありません(しかし、あなたが疑問に思っている場合はPHPです)。

結果の電子メール本文の形式にのみ興味があります。

77
Josef Sábl

ご承知のとおり、電子メールメッセージとして渡されるものはすべてテキスト化する必要があります。

  • Multipart/mimeメッセージを含む電子メールを作成する必要があります。
  • 物理イメージを追加する場合、イメージはBase 64でエンコードされ、Content-ID(cid)が割り当てられている必要があります。 URLの場合、<img />タグで十分です(画像のURLはソースIDにリンクする必要があります)。

典型的な電子メールの例は次のようになります。

From: foo1atbar.net
To: foo2atbar.net
Subject: A simple example
Mime-Version: 1.0
Content-Type: multipart/related; boundary="boundary-example"; type="text/html"

--boundary-example
Content-Type: text/html; charset="US-ASCII"

... text of the HTML document, which might contain a URI
referencing a resource in another body part, for example
through a statement such as:
<IMG SRC="cid:foo4atfoo1atbar.net" ALT="IETF logo">

--boundary-example
Content-Location: CID:somethingatelse ; this header is disregarded
Content-ID: <foo4atfoo1atbar.net>
Content-Type: IMAGE/GIF
Content-Transfer-Encoding: BASE64

R0lGODlhGAGgAPEAAP/////ZRaCgoAAAACH+PUNv
cHlyaWdodCAoQykgMTk5LiBVbmF1dGhvcml6ZWQgZHV
wbGljYXRpb24gcHJvaGliaXRlZC4A etc...

--boundary-example--

ご覧のとおり、Content-ID: <foo4atfoo1atbar.net> IDは<IMG>SRC="cid:foo4atfoo1atbar.net"と一致しています。これにより、クライアントブラウザは、添付ファイルとしてではなく、コンテンツとして画像をレンダリングします。

お役に立てれば。

106
Buhake Sindi

3番目の方法は、画像をbase64でエンコードし、data: urlに配置することです

例:

<img src="" width="32" height="32">
16
Dan D.

以下は、ファイルやbase64ステートメントやmimeを心配せずに埋め込み画像のコードを取得する方法です(base64のままですが、取得するために何もする必要はありません)。もともとこれと同じものを投稿しました このスレッドでの回答 ですが、これも同じように繰り返すのが有益かもしれません。

これを行うには、Mozilla Thunderbirdが必要です。次のような画像のhtmlコードを取得できます。

  1. ビットマップをクリップボードにコピーします。
  2. 新しい電子メールメッセージを開始します。
  3. 画像を貼り付けます。 (ドラフトとして保存しないでください!!!)
  4. それをダブルクリックして、画像設定ダイアログを表示します。
  5. 「画像の場所」プロパティを探します。
  6. コードを取得して、次のように画像タグでラップします。

次のようなテキストの文字列になります。

<img src="" alt="" height="211" width="213">

これを文字列変数にラップし、これをHTMLメールメッセージを表示する任意の場所(メールの署名内であっても)に絶対に配置できます。利点は、添付ファイルがなく、リンクがないことです。 (このコードはトカゲを表示します)

写真は千の言葉に値する: enter image description here

ちなみに、私はあなたのためにこれをすべて行うプログラムを書きました。 これはBaseImageと呼ばれます であり、画像コードとhtmlを作成します。この自己宣伝を考慮しないでください。ソリューションを共有しているだけです。

8
bgmCoder

次は、画像をOutlookに埋め込み、セキュリティの問題を回避する正しい方法です。

  1. Outlook 2003の相互運用機能を使用します。
  2. 新しいメールを作成し、保存フォルダーを設定します。
  3. Base64埋め込みを使用しないでください。Outlook2007ではサポートされていません。ディスク上のファイルを参照しないでください。送信されません。一部のマシンではセキュリティ警告が表示されるため、Wordエディターインスペクターを使用しないでください。
  4. 添付ファイルにはpng/jpg拡張子が必要です。たとえば、tmp拡張子がある場合-Outlookはユーザーに警告します。
  5. MapiなしでCIDが生成される方法に注意してください。
  6. Getterを介してプロパティにアクセスしないでください。アクセスすると、一部のマシンでセキュリティ警告が表示されます。

    public static void PrepareEmail()
    {
        var attachFile = Path.Combine(
            Application.StartupPath, "mySuperImage.png"); // pay attention that image must not contain spaces, because Outlook cannot inline such images
    
        Microsoft.Office.Interop.Outlook.Application Outlook = null;
        NameSpace space = null;
        MAPIFolder folder = null;
        MailItem mail = null;
        Attachment attachment = null;
        try
        {
            Outlook = new Microsoft.Office.Interop.Outlook.Application();
            space = Outlook.GetNamespace("MAPI");
            space.Logon(null, null, true, true);
    
            folder = space.GetDefaultFolder(OlDefaultFolders.olFolderSentMail);
            mail = (MailItem) Outlook.CreateItem(OlItemType.olMailItem);
    
            mail.SaveSentMessageFolder = folder;
            mail.Subject = "Hi Everyone";
            mail.Attachments.Add(attachFile, OlAttachmentType.olByValue, 0, Type.Missing); 
            // Last Type.Missing - is for not to show attachment in attachments list.
    
            string attachmentId = Path.GetFileName(attachFile);
            mail.BodyFormat = OlBodyFormat.olFormatHTML;
    
             mail.HTMLBody = string.Format("<br/><img src=\'cid:{0}\' />", attachmentId);
    
            mail.Display(false);
        }
        finally
        {
            ReleaseComObject(Outlook, space, folder, mail, attachment);
        }
    }
    
7
Siarhei Kuchuk

実際、電子メールに画像を含めるには2つの方法があります。

最初の方法では、場合によってはメッセージの添付ファイルとしてのみであっても、ユーザーに画像が表示されます。この方法は、まさに私たちが日常的に「電子メールに画像を埋め込む」と呼ぶものです。
本質的には、メールに画像を添付しています。プラス面は、何らかの形でユーザーが確実に画像を取得できることです。欠点は2つあります。まず、スパムフィルターは大きな埋め込み画像を検索し、多くの場合、電子メールに画像を埋め込むためのスパムスコアが高くなります(多くのスパマーは画像を使用して、電子メールの不適切なコンテンツがスパムフィルターによって読み取られるのを防ぎます)。第二に、重量またはキロバイト単位でメールを送信するために料金を支払うと、メッセージのサイズが大きくなります。注意しないと、メールプロバイダーのパラメーターに対してメッセージが大きくなりすぎる可能性があります。

画像を含める2番目の方法(およびはるかに一般的な方法)は、Webページに画像を配置する方法と同じです。メールには、ウェブページとまったく同じ方法で、サーバー上の画像の場所への参照であるURLを指定します。これにはいくつかの利点があります。第一に、画像のためにスパムやメッセージの「重さ」に気づかれることはありません。第二に、エラーが見つかった場合、電子メールの送信後に画像を変更できます。反対に、受信者は自分の画像を見るために、メールクライアントで画像表示をアクティブにする必要があります。

4

通常、これを処理するには、IMGタグがコンテンツサーバーを指すHTML形式のSMTPメッセージを設定します。一部の電子メールクライアントはHTML電子メールをサポートできないため、テキストバージョンとHTMLバージョンの両方があることを確認してください。

2
Bob Palmer