简体   繁体   中英

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

I am trying to show an image inside my e-mail. But that image is not getting displayed. I am using base64 string, which I am fetching from S3 bucket.

I am able to get email in inbox, but only thing image is not working when passing url, if directly using base64 hard coded string in html its working.

I need to fetch image from s3 and that image should be inline with email.

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

在此处输入图像描述

I have just resolved this issue... So I thought, about posting answer for others help.

The root cause of this was- large size of my buffer response form S3, and email only supports 128MB data, as I found in cloud watch logs ( I can comment about AWS SES only, not sure about other email clients)

So the ultimate solution for my problem is just to resize the buffer response, which we are getting from S2.

So I have used sharp https://www.npmjs.com/package/sharp

And add these line in index.js

//Here I will resize the image

const resizedImageFileBuffer = await sharp(imageFileBuffer).resize ({ width:200, height:200, fit: 'contain' }).toFormat('png').png({ quality:100, compressionLevel: 6 }).toBuffer()

//Now we will convert resized buffer to base64 let bufferToBase64 = resizedImageFileBuffer.toString("base64");

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM