使用Mailgun和Node.js批量发送电子邮件

时间:2018-03-27 09:16:43

标签: javascript node.js mailgun nodemailer

我使用Mailgun node.js模块发送批量电子邮件。

根据official docs中的大黄色警告消息,指定收件人变量应该导致发送"每个收件人只有个人电子邮件,其中只有他们的电子邮件在收件人中。"

然而,我的收件人可以看到所有"到"地址。我成功地使用了收件人变量来为用户设置电子邮件主题,因此看起来这些正在被正确读取。

请注意,我正在使用MIME发送HTML电子邮件。我尝试使用更直接的纯文本变体,它看起来确实有效。

是否有人能够帮助我理解为什么我的收件人可以看到所有其他收件人?我做错了什么,或者这个功能对Mailgun MIME电子邮件不起作用?

// recipients
var recipients = ['email1@email1.com', 'email2@email2.com', 'email3@email3.com'];
var recipientVars = {
    'email1@email1.com': {
        id: 1,
        subject: 'Subject 1'
    },
    'email2@email2.com': {
        id: 2,
        subject: 'Subject 2'
    },
    'email3@email3.com': {
        id: 3,
        subject: 'Subject 3'
    }
};

// options
var options = {
    from: 'Me <me@me.com>',
    to: recipients,
    'recipient-variables': recipientVars,
    subject: '%recipient.subject%',
    text: myMailText,
    html: myMailHTML,
    headers: {
        'X-Mailgun-Recipient-Variables': JSON.stringify(recipientVars)
    }
};

// create mail
var mail = new nodemailer(options);

// send mail
mail.compile().build((err, message) => {
    var mailData = {
        to: recipients,
        message: message.toString('ascii'),
        'recipient-variables': recipientVars
    };
    mailgun.messages().sendMime(mailData, (err, res) => {
        console.log(res);
    });
});

1 个答案:

答案 0 :(得分:1)

似乎此功能不适用于sendMime()方法,但即使没有任何邮件编译,也可以使用常规send()方法。这是工作代码片段:

const mailgun = require('mailgun-js')({
  apiKey: 'api_key',
  domain: 'domain'
});

const recipients = ['email1@gmail.com', 'email2@gmail.com'];
const recipientVars = {
  'email1@gmail.com': {
    id: 1,
    subject: 'Subject 1',
    name: 'Name 1'
  },
  'email2@gmail.com': {
    id: 2,
    subject: 'Subject 2',
    name: 'Name 2'
  }
};

const envelope = {
  from: 'Sender <sender@gmail.com>',
  to: recipients,
  subject: '%recipient.subject%',
  html: 'Hey <strong>%recipient.name%<strong>',
  'recipient-variables': recipientVars,
};

mailgun.messages().send(envelope, function (error, body) {
  console.log(body);
});

您会注意到所有占位符都已填充且<strong>标记已正确呈现。