Node.js使用NodeMailer发送邮件实例代码

前端之家收集整理的这篇文章主要介绍了Node.js使用NodeMailer发送邮件实例代码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

0.目标

这一节,我将实现一个简单的发送邮件功能

1.部署

1.1 部署Express

如果不知道如何部署,可参照:

1.2 准备一个邮箱并开始SMTP服务

为了实现这个功能,你首先要有一个邮箱;由于需要使用SMTP方式发送,你还需要开启相关功能。你可以登录你的邮箱,然后开启这个设置,以新浪邮箱和QQ邮箱为例:

2.服务器端

2.1 使用nodemailer

这里要用到nodemailer,需要自行安装:

在routes/index.js中引用nodemailer:

2.2 配置

在routes/index.js中创建一个传输方式:

注意,低版本的nodemailer可能需要多传入一个参数“SMTP”:

2.3 发送邮件

',to : '"用户1" @H_301_66@,"用户2" <邮箱地址2>',// cc : '' //抄送 // bcc : '' //密送 subject : '一封来自Node Mailer的邮件',text : '一封来自Node Mailer的邮件',html : '

你好,这是一封来自NodeMailer的邮件

',attachments : [ { filename: 'img1.png',// 改成你的附件名 path: 'public/images/img1.png',// 改成你的附件路径 cid : '00000001' // cid可被邮件使用 },{ filename: 'img2.png',// 改成你的附件名 path: 'public/images/img2.png',// 改成你的附件路径 cid : '00000002' // cid可被邮件使用 },] };

mailTransport.sendMail(options,function(err,msg){
if(err){
console.log(err);
res.render('index',{ title: err });
}
else {
console.log(msg);
res.render('index',{ title: "已接收:"+msg.accepted});
}
});
});

如果你要发送附件,则先把要发送的文件放入工程中,并修改上面代码的附件的filename和path。

代码中可以知道,要在邮件正文中添加图片,可以设置图片的cid,然后在img标签的src中设置为对应的cid即可。

注意,不建议在js代码中直接嵌入HTML代码,也不建议把图片加到邮件正文中。

3.测试

浏览器输入地址(如127.0.0.1:3000/sned)。

发送等待的时间视附件大小及网络带宽等因素不同,如果有一个很大的附件要发送,可能会等待很长时间;所以,建议在测试的时候使用小文件

如果发送成功,会给出提示

并在邮箱里收到相应的邮件

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

猜你在找的Node.js相关文章