Base64 编码的图像未在 gmail 中显示

问题描述 投票:0回答:3

我有一封嵌入的 HTML 电子邮件,其中使用了

base64
编码图像。通过 Chrome 访问时,图像不会在 Gmail 中显示。但当通过邮件客户端(Mac 上的邮件应用程序)访问相同的邮件时,它工作正常。我已正确设置标题。有什么想法吗?

我的代码

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

标题

Content-Type: text/html; charset=utf-8
Content-Transfer-Encoding: quoted-printable
html gmail base64 html-email
3个回答
84
投票

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


使用 Base64 编码图像时需要注意的另一件事是电子邮件文件大小。 Gmail 应用程序(iOS、Android)和 Outlook (iOS) 会截断文件大小超过 102KB 的电子邮件。远程引用的图像(例如,

<img src="http://www.website.com/image.png">

 不计入电子邮件的文件大小,
但使用 Base64 编码的图像do,并且可以快速使电子邮件的文件大小超过 102KB 限制。还有其他需要考虑的事情。


12
投票
看起来 gmail 也不支持直接编码图像(非 bease64 ):( - 我编写下面的代码片段以将图像从 base64 转换为直接形式并通过电子邮件发送 - 但仍然看不到任何图像 :( 。解决这个问题,您需要使用 cid 添加图像作为附件,并在 img 标签中使用该 cid

<img src="cid:123456">

 - 更多详细信息
这里

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'>


0
投票
如果您使用 Java,JavaMailSender 已经有一个辅助方法。

在您的模板中,具有如下所示的图像标签。

<img src="cid:header-logo">
然后,在您的电子邮件逻辑中,将附件添加为内联。

helper.addInline("header-logo", new ClassPathResource("mail/images/header-logo.png"));
    
© www.soinside.com 2019 - 2024. All rights reserved.