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 prototype 格式化数字 By shawl.qiu
Apr 02 Javascript
基于jQuery实现的当离开页面时出现提示的实现代码
Jun 27 Javascript
jQuery探测位置的提示弹窗(toolTip box)详细解析
Nov 14 Javascript
jQuery+CSS3实现四种应用广泛的导航条制作实例详解
Sep 17 Javascript
JS实现禁止高频率连续点击的方法【基于ES6语法】
Apr 25 Javascript
vue实现表格增删改查效果的实例代码
Jul 18 Javascript
angularJs中json数据转换与本地存储的实例
Oct 08 Javascript
vue组件间通信六种方式(总结篇)
May 15 Javascript
微信小程序wxs实现吸顶效果
Jan 08 Javascript
使用js实现单链解决前端队列问题的方法
Feb 03 Javascript
vue滑动吸顶及锚点定位的示例代码
May 10 Javascript
使用element-ui +Vue 解决 table 里包含表单验证的问题
Jul 17 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编程效率的方法
2013/11/07 PHP
PHP中require和include路径问题详解
2014/12/25 PHP
postman的安装与使用方法(模拟Get和Post请求)
2018/08/06 PHP
PHP使用ActiveMQ实现消息队列的方法详解
2019/05/31 PHP
javascript 处理事件绑定的一些兼容写法
2009/12/24 Javascript
JS中动态添加事件(绑定事件)的代码
2011/01/09 Javascript
js常用数组操作方法简明总结
2014/06/20 Javascript
jQuery标签编辑插件Tagit使用指南
2015/04/21 Javascript
JavaScript中的toDateString()方法使用详解
2015/06/12 Javascript
总结Javascript中的隐式类型转换
2016/08/24 Javascript
微信小程序 定位到当前城市实现实例代码
2017/02/23 Javascript
Vue 2.5.2下axios + express 本地请求404的解决方法
2018/02/21 Javascript
在小程序/mpvue中使用flyio发起网络请求的方法
2018/09/13 Javascript
NVM安装nodejs的方法实用步骤
2019/01/16 NodeJs
VUE v-model表单数据双向绑定完整示例
2019/01/21 Javascript
Angular 2使用路由自定义弹出组件toast操作示例
2019/05/10 Javascript
关于NodeJS中的循环引用详解
2019/07/23 NodeJs
详解Nuxt.js 实战集锦
2019/11/19 Javascript
[01:10:16]DOTA2上海特级锦标赛B组资格赛#2 Fnatic VS Spirit第一局
2016/02/27 DOTA
Swift中的协议(protocol)学习教程
2016/07/08 Python
django中的setting最佳配置小结
2017/11/21 Python
Python2.7实现多进程下开发多线程示例
2019/05/31 Python
详解Python中打乱列表顺序random.shuffle()的使用方法
2019/11/11 Python
Python编程快速上手——Excel到CSV的转换程序案例分析
2020/02/28 Python
Python urlencode和unquote函数使用实例解析
2020/03/31 Python
python3 自动打印出最新版本执行的mysql2redis实例
2020/04/09 Python
python实现密度聚类(模板代码+sklearn代码)
2020/04/27 Python
女子锻炼服装和瑜伽服装:Splits59
2019/03/04 全球购物
垃圾回收的优点和原理
2014/05/16 面试题
小学生暑假家长评语
2014/04/17 职场文书
五水共治一句话承诺
2014/05/30 职场文书
会计专业自荐信
2014/06/03 职场文书
2014年高三班主任工作总结
2014/12/05 职场文书
经营场所使用证明
2015/06/19 职场文书
爱国之歌(8首)
2019/09/29 职场文书
GitHub上77.9K的Axios项目有哪些值得借鉴的地方详析
2021/06/15 Javascript