本文实例讲述了node.js发送邮件email的方法。分享给大家供大家参考,具体如下:
通常我们做node项目时,可能我们会碰到做一个简单的邮件反馈,那么我们今天就来讨论一下,其中遇到的各种坑。
总的来说做这个东西,我们可能需要node第三方依赖模块,来实现我们要达到的效果。
这里我推荐两个模块:https://github.com/pingfanren/Nodemailer
npm install nodemailer //这个模块不错,github上星也比较多,还经常有维护,但是坑也比较多
另一个,https://github.com/eleith/emailjs
npm install emailjs --save
这里我用的是nodemailer模块,毕竟用的人比较多,跟随主流呢
它的特点:
使用Unicode编码
支持Windows系统,不需要安装依赖
支持纯文本和HTML格式
支持发送附件(包括大型附件)
在HTML中嵌入图片
支持SSL/STARTTLS安全协议
不同的传输方法,可以使用内置也可以使用外部插件的形式
提供自定义插件支持(比如增加DKIM签名,使用markdown代替HTML等等)
支持XOAUTH2登录验证(以及关于更新的令牌反馈)
安装使用
npm install nodemailer --save
使用内置传输发送邮件,可以查看支持列表:https://github.com/andris9/nodemailer-wellknown#supported-services
var nodemailer = require('nodemailer'); var transporter = nodemailer.createTransport({ //https://github.com/andris9/nodemailer-wellknown#supported-services 支持列表 service: 'qq', port: 465, // SMTP 端口 secureConnection: true, // 使用 SSL auth: { user: '768065158@qq.com', //这里密码不是qq密码,是你设置的smtp密码 pass: '*****' } }); // NB! No need to recreate the transporter object. You can use // the same transporter object for all e-mails // setup e-mail data with unicode symbols var mailOptions = { from: '768065158@qq.com', // 发件地址 to: '528779822@qq.com', // 收件列表 subject: 'Hello sir', // 标题 //text和html两者只支持一种 text: 'Hello world "htmlcode">npm install nodemailer-smtp-transport --save其他代码类似,差别只是在创建transport上,所以这里我就写一部分代码:
var nodemailer = require('nodemailer'); var smtpTransport = require('nodemailer-smtp-transport'); // 开启一个 SMTP 连接池 var transport = nodemailer.createTransport(smtpTransport({ host: "smtp.qq.com", // 主机 secure: true, // 使用 SSL secureConnection: true, // 使用 SSL port: 465, // SMTP 端口 auth: { user: "gaolu19901228@qq.com", // 账号 pass: "******" // 密码 } })); // 设置邮件内容 var mailOptions = { from: "768065158<768065158@qq.com>", // 发件地址 to: "528779822@qq.com", // 收件列表 subject: "Hello world", // 标题 text:"hello", html: "<b>thanks a for visiting!</b> 世界,你好!" // html 内容 } // 发送邮件 transport.sendMail(mailOptions, function(error, response) { if (error) { console.error(error); } else { console.log(response); } transport.close(); // 如果没用,关闭连接池 });下面列出了一些发邮件的字段:
from 发送者邮箱
sender 发送者区域显示的信息
to 接收者邮箱
cc 抄送者邮箱
bcc 密送者邮箱
subject 邮箱主题
attachments 附件内容
watchHtml apple watch指定的html版本
text 文本信息
html html内容
headers 另加头信息
encoding 编码格式邮件内容使用UTF-8格式,附件使用二进制流。
附件
附件对象包含了下面这些属性:
filename 附件名
content 内容
encoding 编码格式
path 文件路径
contentType 附件内容类型常见错误
1.账号未设置该服务
{ [AuthError: Invalid login - 454 Authentication failed, please open smtp flag first!] name: 'AuthError', data: '454 Authentication failed, please open smtp flag first!', stage: 'auth' }解决方案:
QQ邮箱 -> 设置 -> 帐户 -> 开启服务:POP3/SMTP服务
2.发件账号与认证账号不同
{ [SenderError: Mail from command failed - 501 mail from address must be same as authorization user] name: 'SenderError', data: '501 mail from address must be same as authorization user', stage: 'mail' }3.登录认证失败,可能由于smpt独立密码错误导致 我在qq设置的时候就遇到过
Invalid login - 535 Authentication failed解决方案:
qq邮箱在测试smtp邮件服务器时,一,在qq邮箱,设置,账户设置中.开启下smtp.二,设置一下独立密码.三,在配置smtp服务器的密码时,注意一定要填你设置的独立密码.不要用邮箱登录密码.否则会提示535 Authentication failed错误.
希望本文所述对大家nodejs程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]