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 版
Mar 24 Javascript
javascript 常用功能总结
Mar 18 Javascript
jQuery布局插件UI Layout简介及使用方法
Apr 03 Javascript
jQuery实现TAB风格的全国省份城市滑动切换效果代码
Aug 24 Javascript
认识jQuery的Promise的具体使用方法
Oct 10 jQuery
webpack4+Vue搭建自己的Vue-cli项目过程分享
Aug 29 Javascript
JavaScript函数、闭包、原型、面向对象学习笔记
Sep 06 Javascript
vscode下的vue文件格式化问题
Nov 28 Javascript
JavaScript函数式编程(Functional Programming)纯函数用法分析
May 22 Javascript
layui使用form表单实现post请求页面跳转的方法
Sep 14 Javascript
Vue文本模糊匹配功能如何实现
Jul 30 Javascript
vue+elementUI动态增加表单项并添加验证的代码详解
Dec 17 Vue.js
利用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 curl模拟post提交数据示例
2013/12/31 PHP
php实现常见图片格式的水印和缩略图制作(面向对象)
2016/06/15 PHP
PHP扩展类型及安装方式解析
2020/04/27 PHP
非常不错的一个javascript 类
2006/11/07 Javascript
云网广告中的代码,提示出错,大家找找
2006/11/21 Javascript
文本框获得焦点和失去焦点的判断代码
2012/03/18 Javascript
Three.js源码阅读笔记(物体是如何组织的)
2012/12/27 Javascript
IE下JS读取xml文件示例代码
2013/08/05 Javascript
jQuery aminate方法定位到页面具体位置
2013/12/26 Javascript
JQuery中的事件及动画用法实例
2015/01/26 Javascript
jquery实现标签上移、下移、置顶
2015/04/26 Javascript
JavaScript之面向对象_动力节点Java学院整理
2017/06/29 Javascript
pm2 部署 node的三种方法示例
2017/10/20 Javascript
JavaScript使用享元模式实现文件上传优化操作示例
2018/08/07 Javascript
JavaScript遍历DOM元素的常见方式示例
2019/02/16 Javascript
简单了解JavaScript异步
2019/05/23 Javascript
vue从一个页面跳转到另一个页面并携带参数的解决方法
2019/08/12 Javascript
python 参数列表中的self 显式不等于冗余
2008/12/01 Python
CSS3 渐变(Gradients)之CSS3 线性渐变
2016/07/08 HTML / CSS
简单整理HTML5的基本特性和语法
2016/02/18 HTML / CSS
婴儿鞋,独特的婴儿服装和配件:Zutano
2018/11/03 全球购物
英国最大的独立摄影零售商:Park Cameras
2019/11/27 全球购物
银行求职推荐信范文
2013/11/30 职场文书
三好学生自我鉴定
2013/12/17 职场文书
员工培训邀请函
2014/01/11 职场文书
金融管理应届生求职信
2014/02/20 职场文书
超越自我演讲稿
2014/05/21 职场文书
计算机系统管理员求职信
2014/06/20 职场文书
英语系本科生求职信
2014/07/15 职场文书
2015纪念九一八事变84周年演讲稿
2015/03/19 职场文书
文化苦旅读书笔记
2015/06/29 职场文书
幼儿园元旦主持词
2015/07/06 职场文书
《当代神农氏》教学反思
2016/02/23 职场文书
解决tk mapper 通用mapper的bug问题
2021/06/16 Java/Android
python读取mnist数据集方法案例详解
2021/09/04 Python
JDK8中String的intern()方法实例详细解读
2022/09/23 Java/Android