node.js发送邮件email的方法详解


Posted in Javascript onJanuary 06, 2017

本文实例讲述了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 ?', // 标题
  html: '<b>Hello world ?</b>' // html 内容
};
// send mail with defined transport object
transporter.sendMail(mailOptions, function(error, info){
  if(error){
    return console.log(error);
  }
  console.log('Message sent: ' + info.response);
});

发送邮件成功以后我们很少会有操作,但也有极少数情况需要在成功以后会处理一些特殊信息的,这时候info对象就能发挥余热了。info对象中包含了messageId、envelop、accepted和response等属性,具体看文档我不一一介绍了。

使用其他传输插件   https://github.com/andris9/nodemailer-smtp-transport

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程序设计有所帮助。

Javascript 相关文章推荐
js获取网页可见区域、正文以及屏幕分辨率的高度
May 15 Javascript
jQuery通过ajax请求php遍历json数组到table中的代码(推荐)
Jun 12 Javascript
jq给页面添加覆盖层遮罩的实例
Feb 16 Javascript
Ionic + Angular.js实现图片轮播的方法示例
May 21 Javascript
Vue.js结合Ueditor富文本编辑器的实例代码
Jul 11 Javascript
详解vue前后台数据交互vue-resource文档
Jul 19 Javascript
React Native中导航组件react-navigation跨tab路由处理详解
Oct 31 Javascript
VUE简单的定时器实时刷新的实现方法
Jan 20 Javascript
了解javascript中的Dom操作
May 27 Javascript
webpack优化之代码分割与公共代码提取详解
Nov 22 Javascript
JS深入学习之数组对象排序操作示例
May 01 Javascript
JSONP 的原理、理解 与 实例分析
May 16 Javascript
利用jquery实现实时更新歌词的方法
Jan 06 #Javascript
Ajax 加载数据 练习代码
Jan 05 #Javascript
JavaScript中Math对象的方法介绍
Jan 05 #Javascript
微信小程序 Tab页切换更新数据
Jan 05 #Javascript
微信小程序 省市区选择器实例详解(附源码下载)
Jan 05 #Javascript
微信小程序 Template详解及简单实例
Jan 05 #Javascript
echarts3 使用总结(绘制各种图表,地图)
Jan 05 #Javascript
You might like
功能强大的PHP POST提交数据类
2016/07/15 PHP
JavaScript 在线压缩和格式化收藏
2009/01/16 Javascript
改写一个简单的菜单 弹性大小
2010/12/02 Javascript
javascript真的不难-回顾一下基础知识
2013/01/15 Javascript
如何实现修改密码时密码框显示保存到cookie的密码
2013/12/10 Javascript
nodejs中实现路由功能
2014/12/29 NodeJs
Javascript页面跳转常见实现方式汇总
2015/11/28 Javascript
Bootstrap每天必学之滚动监听
2016/03/16 Javascript
canvas实现动态小球重叠效果
2017/02/06 Javascript
详解Ant Design of React的安装和使用方法
2018/12/27 Javascript
javascript解析json格式的数据方法详解
2020/08/07 Javascript
解决antd日期选择组件,添加value就无法点击下一年和下一月问题
2020/10/29 Javascript
javascript实现简单留言板案例
2021/02/09 Javascript
python self,cls,decorator的理解
2009/07/13 Python
Python中matplotlib中文乱码解决办法
2017/05/12 Python
python求解数组中两个字符串的最小距离
2018/09/27 Python
详解pyppeteer(python版puppeteer)基本使用
2019/06/12 Python
python多维数组分位数的求取方式
2020/03/03 Python
Python importlib动态导入模块实现代码
2020/04/16 Python
实例代码讲解Python 线程池
2020/08/24 Python
使用OpenCV校准鱼眼镜头的方法
2020/11/26 Python
HTML5 canvas基本绘图之绘制阴影效果
2016/06/27 HTML / CSS
美国婚礼装饰和活动用品批发供应商:Event Decor Direct
2018/10/12 全球购物
Dogeared官网:在美国手工制作的珠宝
2019/08/24 全球购物
"火柴棍式"程序员面试题
2014/03/16 面试题
事业单位个人应聘自荐信
2013/09/21 职场文书
户外宣传策划方案
2014/05/25 职场文书
2014年党风廉政工作总结
2014/12/03 职场文书
2014年学校后勤工作总结
2014/12/06 职场文书
家庭经济困难证明
2015/06/23 职场文书
2015秋季开学典礼演讲稿
2015/07/16 职场文书
学生会2016感恩节活动小结
2016/04/01 职场文书
忆童年!用Python实现愤怒的小鸟游戏
2021/06/07 Python
《勇者辞职不干了》ED主题曲无字幕动画MV公开
2022/04/13 日漫
Python中npy和mat文件的保存与读取
2022/04/24 Python
Apache SkyWalking 监控 MySQL Server 实战解析
2022/09/23 Servers