Как вставлять изображения в электронную почту

Мне нужно встроить изображение в электронную почту. Как это сделать?

Я не хочу использовать сторонний инструмент, и я не заинтересован в конкретном ответе на язык (но это PHP, если вам интересно).

Меня интересует только формат полученного тела электронной почты.

Ответ 1

Как вам известно, все прошло, поскольку сообщение электронной почты должно быть текстуализировано.

  • Необходимо создать электронное письмо с сообщением multipart/mime.
  • Если вы добавляете физическое изображение, изображение должно быть закодировано в базе 64 и назначено Content-ID (cid). Если это URL-адрес, то тег <img /> достаточен (URL-адрес изображения должен быть связан с идентификатором источника).

A Типичный пример электронной почты будет выглядеть следующим образом:

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> сопоставляется с <IMG> в SRC="cid:foo4atfoo1atbar.net". Таким образом, клиентский браузер будет отображать ваше изображение как контент, а не как прикрепление.

Надеюсь, что это поможет.

Ответ 2

третий способ - base64 закодировать изображение и поместить его в data: url

Пример:

<img src="" width="32" height="32">

Ответ 3

Правильный способ встраивания изображений в Outlook и предотвращения проблем безопасности следующий:

  • Использовать interop для Outlook 2003;
  • Создать новое электронное письмо и установить его папку сохранения;
  • Не используйте встраивание base64, Outlook 2007 не поддерживает его; не ссылайтесь на файлы на своем диске, они не будут отправлены; не используйте инспектор текстовых редакторов, потому что вы получите предупреждения о безопасности на некоторых машинах;
  • Вложение должно иметь расширение png/jpg. Если это будет, например, расширение tmp - Outlook будет предупреждать пользователя;
  • Обратите внимание, что CID генерируется без mapi;
  • Не обращайтесь к свойствам через getters или вы получите предупреждения о безопасности на некоторых машинах.

    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);
        }
    }
    

Ответ 4

Вот как получить код для встроенного изображения, не беспокоясь о каких-либо файлах или операциях base64 или mimes (он все еще base64, но вам не нужно ничего делать, чтобы получить его). Я изначально опубликовал этот ответ в этом потоке, но может быть полезно повторить его и в этом.

Для этого вам понадобится Mozilla Thunderbird, вы можете получить html-код для изображения следующим образом:

  • Скопируйте растровое изображение в буфер обмена.
  • Запустите новое сообщение электронной почты.
  • Вставить изображение. (не сохраняйте его как черновик!!!)
  • Дважды щелкните по нему, чтобы перейти в диалог настроек изображения.
  • Найдите свойство "местоположение изображения".
  • Извлеките код и оберните его в тег изображения, например:

В итоге вы получите строку с текстом примерно так:

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

Вы можете обернуть это в строковую переменную и поместить это абсолютно в любом месте, где бы вы представляли html-сообщение электронной почты, даже в ваших подписях электронной почты. Преимущество состоит в том, что нет вложений, и ссылок нет. (этот код отобразит ящерицу)

Картинка стоит тысячи слов: enter image description here

Ответ 5

На самом деле есть два способа включить изображения в электронную почту.

Первый способ гарантирует, что пользователь увидит изображение, даже если он в некоторых случаях является только вложением в сообщение. Этот метод является тем, что мы называем "встраиванием изображений в электронную почту" в повседневной жизни.
По сути, вы прикрепляете изображение к письму. Сторона плюса состоит в том, что, так или иначе, пользователь обязательно получит изображение. В то время как недостаток в два раза. Во-первых, спам-фильтры ищут большие встроенные изображения и часто дают вам более высокий рейтинг спама для встраивания изображений в электронную почту (многие спамеры используют изображения, чтобы избежать нежелательного содержимого в своих письмах, прочитанных фильтрами спама). Во-вторых, если вы платите за отправку электронной почты по весу или килобайту, это увеличивает размер вашего сообщения. Если вы не будете осторожны, это может даже сделать ваше сообщение слишком большим для параметров поставщика электронной почты.

Второй способ включения изображений (и гораздо более общий способ) - это то же самое, что вы помещаете изображение на веб-страницу. Внутри электронной почты вы указываете URL-адрес, который является ссылкой на местоположение изображений на вашем сервере, точно так же, как на веб-странице. Это имеет несколько преимуществ. Во-первых, вы не будете пойманы для рассылки спама или для вашего сообщения, "взвешивающего" слишком много из-за изображения. Во-вторых, вы можете вносить изменения в изображения после отправки сообщения электронной почты, если вы обнаружите в них ошибки. С другой стороны, вашему получателю необходимо будет активно включить просмотр изображений в своем почтовом клиенте, чтобы увидеть ваши изображения.

Ответ 6

Обычно я обрабатываю это, настраивая SMTP-сообщение в формате HTML, с тегами IMG, указывающими на сервер содержимого. Просто убедитесь, что у вас есть как текстовые, так и HTML-версии, так как некоторые почтовые клиенты не могут поддерживать электронные письма HTML.