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


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

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

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

6 76

6 ответов:

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

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

типичный пример электронной почты будет выглядеть так:

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

надеюсь, что это помогает.

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

пример:

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

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

  1. использовать взаимодействие для Outlook 2003;
  2. создать новый адрес электронной почты и установить его сохранить папку;
  3. не используйте встраивание base64, outlook 2007 не поддерживает его; не ссылайтесь на файлы на вашем диске, они не будут отправлены; не используйте Word editor inspector, потому что вы получите предупреждения безопасности на некоторых машинах;
  4. вложение должно иметь расширение png/jpg. Если он будет иметь, например, расширение tmp-Outlook предупредит пользователя;
  5. обратите внимание, как CID генерируется без mapi;
  6. Не доступ к свойствам через геттеры или вы получите предупреждение о безопасности на некоторых машинах.

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

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

для этого нужно Mozilla Thunderbird, вы можете получить HTML код для картинки такой:

  1. скопируйте растровое изображение в буфер.
  2. создать новое сообщение электронной почты.
  3. вставить изображение. (не сохраняйте его как черновик!!!)
  4. дважды щелкните по нему, чтобы перейти к диалогу настроек изображения.
  5. найдите свойство "местоположение изображения".
  6. извлеките код и оберните его в тег изображения, например:

вы должны в конечном итоге со строкой текста что-то вроде этого:

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

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

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

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

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

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

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