如何使用 AWS SES 在电子邮件中将 base64 字符串显示为图像

How to display base64 string as image in email, using AWS SES

我想在我的电子邮件中显示图片。但是该图像没有显示。我正在使用从 S3 存储桶中获取的 base64 字符串。

我可以在收件箱中收到电子邮件,但只有在传递 url 时图像无法正常工作,如果直接在 html 中使用 base64 硬编码字符串,它就可以正常工作。

我需要从 s3 获取图像,该图像应该与电子邮件内联。

"use strict";
const fs = require("fs");
const path = require("path")
const Handlebars = require('handlebars');
const {SESClient, sendEmailCommand} = require("@aws-sdk/client-ses");
const {S3Client, GetObjectCommand} = require("@aws-sdk/client-s3");

let S3=null, SES=null;

const streamToBuffer = async(stream) =>{
  return new Promise((resolve, reject) =>{
    const chunks = [];
    stream.on("data", (chunk) =>{chunks.push(chunk)});
    stream.on("error", reject);
    stream.on("end", () =>{resolve(Buffer.conact(chunks))});
  })
}


export.handler = async(event) =>{
  if(S3 === null){
    S3 = new S3Client ({region: MY_REGION})
  }
  
  if(SES === null){
    SES = new SESClient ({region: MY_REGION})
  }
  try{
   let deatils = event.detail.fullDocument;
   
   let imageKey = `${deatils.dir}/myimage.png`;
   
   let imageFileFromS3 = await S3.send(
                         new GetObjectCommand({
                         Bucket: MY_BUCKET_NAME, key: imageKey 
                         }))
   let imageFileBuffer = await streamToBuffer(imageFileFromS3.Body)
   let bufferToBase64 = imageFileBuffer.toString("base64");
   
   const emailSubject = "Hey!! Test mail with image";
   const emailData = {
    Name: "Email Tester"
    ImageSrc: `data:image/png;base64, ${bufferToBase64}`
   }
   
   let htmlTemplate =       Handlebars.complie(fs.readFileSync(path.join(__dirname, 'templateSrc', email.html)).toString())
   
   let textTemplate = Handlebars.complie(fs.readFileSync(path.join(__dirname, 'templateSrc', email.txt)).toString())
   
   let emailResult = await SES.send( new SendEmailCommand({
    Source: "Source_test@email.com", //dummy email for now
    Destination :{
      ToAddress: ["to_test@email.com"] // dummy address 
    },
    Message: {
      Subject: {
        Charset: 'UTF-8',
        Data: emailSubject
      },
      Body: {
        Text: {
          Charset: 'UTF-8',
          Data: textTemplate(emailData)
        },
        Html:{
          Charset: 'UTF-8',
          Data: htmlTemplate(emailData)
        }
      }
    }
   }))
   return emailResult
  }catch(error){
    console.log(error)
  }
  
  
}
email.txt

Dear {{Name}}

Thanks for asking images on email.

Please find your requested images below
   
 Face image

 Bus image

   -----Thanks
Email.html

<h1>Dear {{Name}}</h1>
<p>Thanks for asking images on email.</p>
<p>Please find your requested image below</p>

 <p>face Image</p>
 <img src={{ImageSrc}} />

  <p>Bus Image</p>
<img src="">

//This image is working
 
<p>-------Thanks</p>

我刚刚解决了这个问题... 所以我想,关于发布答案以帮助其他人。

根本原因是-我的缓冲区响应表单 S3 很大,电子邮件只支持 128MB 数据,正如我在云监视日志中发现的那样(我只能评论 AWS SES,不确定其他电子邮件客户端)

所以我的问题的最终解决方案就是调整我们从 S2 获得的缓冲区响应的大小。

所以我用了sharp https://www.npmjs.com/package/sharp

并在 index.js

中添加这些行

//这里我会调整图片大小

const resizedImageFileBuffer = 等待夏普(imageFileBuffer) .调整大小({ width:200, height:200, 适合:'contain' }) .toFormat('png') .png({ quality:100, 压缩级别:6 }) .toBuffer()

//现在我们将调整大小的缓冲区转换为base64 让 bufferToBase64 = resizedImageFileBuffer.toString("base64");