Gmail 中未显示 Base64 编码图像

Base64 encoded image is not showing in gmail

我有一个嵌入式 HTML 电子邮件,其中我使用了 base64 编码图像。通过 chrome 访问时,图片未显示在 gmail 中。但是当通过邮件客户端(Mac 上的邮件应用程序)访问相同的邮件时它工作正常。我已正确设置 headers。有什么想法吗?

我的代码

<html>
    <body>Hi
        <img src="" width="273" height="11" alt="">
    </body>
</html>

Headers

Content-Type: text/html; charset=utf-8
Content-Transfer-Encoding: quoted-printable

base64 编码图像在电子邮件中得不到很好的支持。 大多数 Web 电子邮件客户端(包括 Gmail)不支持它们,并且在 Outlook 中被完全阻止。 Apple Mail 是少数 支持它们的客户端之一,这就是为什么您可以在那里看到它们但在其他地方看不到的原因。


使用 base64 编码图像时要注意的另一件事是电子邮件文件的大小。 Gmail 应用程序 (iOS、Android) 和 Outlook (iOS) 会截断文件大小超过 102KB 的电子邮件。远程引用的图像(例如 <img src="http://www.website.com/image.png"> 不计入电子邮件的文件大小, 但 base64 编码的图像 do 并且可以快速爆炸超过 102KB 限制的电子邮件文件大小。只是其他需要考虑的事情。

看起来 gmail 也不支持直接编码图像(非 bease64):( - 我在下面写了一段代码,将图像从 base64 转换为直接格式并通过电子邮件发送 - 但仍然看不到任何图像:( 。要解决此问题,您需要将图像添加为带有 cid 的附件,并在 img 标签中使用该 cid <img src="cid:123456"> - 更多详细信息 here

function convert() {
  let base64 = imageBase64.value.split('base64,')[1];
  let hex = [...atob(base64)].map(c => c.charCodeAt(0).toString(16).padStart(2, 0));
  let img = 'data:image/png,%' + hex.join('%');

  pic.src = img;
  msg.innerText = img;
}
Put your img base64 data uri here<br>
<input style="width:200px" id='imageBase64' value="">
<button onclick="convert()">Convert</button><br> Result
<br>
<textarea id='msg' rows="4" cols="50"></textarea><br>
<img id='pic'>