NodeJs之邮件(email)发送
NodeJs之邮件(email)发送
一,介绍与需求
1.1,介绍
1,Nodemailer简介
Nodemailer是一个简单易用的Node.js邮件发送插件
Nodemailer的主要特点包括:
- 支持Unicode编码
- 支持Window系统环境,不需要安装依赖
- 支持HTML内容和普通文本text内容
- 支持附件(传送大附件)
- 支持HTML内容中嵌入图片
- 支持SSL/STARTTLS安全的邮件发送
- 支持内置的transport方法和其他插件实现的transport方法
- 支持自定义插件处理消息
- 支持XOAUTH2登录验证
常见发邮件的字段:
- from 发送者邮箱
- sender 发送者区域显示的信息
- to 接收者邮箱
- cc 抄送者邮箱
- bcc 密送者邮箱
- subject 邮箱主题
- attachments 附件内容
- watchHtml apple watch指定的html版本
- text 文本信息
- html html内容
- headers 另加头信息
- encoding 编码格式
邮件内容使用UTF-8格式,附件使用二进制流。
附件
附件对象包含了下面这些属性:
- filename 附件名
- content 内容
- encoding 编码格式
- path 文件路径
- contentType 附件内容类型
2,emailjs简介
emailjs是一个简单易用的Node.js邮件发送插件
npm install emailjs --save
下面讲的主要是Nodemailer发送邮件,毕竟星比较多嘛
1.2,需求
电子邮件是—种用电子手段提供信息交换的通信方式,是互联网应用最广的服务。通过网络的电子邮件系统,用户可以以非常低廉的价格(不管发送到哪里,都只需负担网费)、非常快速的方式(几秒钟之内可以发送到世界上任何指定的目的地),与世界上任何一个角落的网络用户联系。
在很多项目中,我们都会遇到邮件注册,邮件反馈等需求。在node中收发电子邮件也非常简单,因为强大的社区有各种各样的包可以供我么直接使用。
二,配置使用
主要讲的是Nodemailer发送邮件
第一步:安装Nodemailer
npm install nodemailer --save
第二步:配置参数xml
<?xml version="1.0" encoding="utf-8" ?>
<appSettings>
<add key="smtp" value="smtp.qq.com"/>
<!-- 配置服务 smtp.exmail.qq.com//企业邮箱 非qq; -->
<add key="mailFrom" value="*@qq.com"/>
<!--配置发送邮箱 -->
<add key="mailPwd" value="v567jvsvqajos67e"/>
<!--smtp授权码 -->
</appSettings>
第三步:封装发送邮件方法
使用内置传输的方式发送邮件,在sendEmail.js添加如下代码:
var nodemailer = require("nodemailer");
var settingConfig = require('../config/settingConfig.js');//解析参数
var smtp = settingConfig.getValueByKey("smtp");
var mailFrom = settingConfig.getValueByKey("mailFrom");
var mailPwd = settingConfig.getValueByKey("mailPwd");
function emailTo(email,subject,text,html,callback) {
var transporter = nodemailer.createTransport({
host: smtp,
auth: {
user: mailFrom,
pass: mailPwd //授权码,通过QQ获取
}
});
var mailOptions = {
from: mailFrom, // 发送者
to: email, // 接受者,可以同时发送多个,以逗号隔开
subject: subject, // 标题
};
if(text != undefined)
{
mailOptions.text =text;// 文本
}
if(html != undefined)
{
mailOptions.html =html;// html
}
var result = {
httpCode: 200,
message: '发送成功!',
}
try {
transporter.sendMail(mailOptions, function (err, info) {
if (err) {
result.httpCode = 500;
result.message = err;
callback(result);
return;
}
callback(result);
});
} catch (err) {
result.httpCode = 500;
result.message = err;
callback(result);
}
}
使用其他传输插件 https://github.com/andris9/nodemailer-smtp-transport,
安装插件
npm install nodemailer-smtp-transport --save
其他代码类似,差别只是在创建transport上,所以这里我就写一部分代码:
var nodemailer = require('nodemailer');
var smtpTransport = require('nodemailer-smtp-transport');
function emailTo(email,subject,text,html,callback) {
// 开启一个 SMTP 连接池
var transporter = nodemailer.createTransport(smtpTransport({
host: smtp,//主机
secure: true, // 使用 SSL
secureConnection: true, // 使用 SSL
port: 465, // SMTP 端口
auth: {
user: mailFrom,
pass: mailPwd //授权码,通过QQ获取
}
}));
var mailOptions = {
from: mailFrom, // 发送者
to: email, // 接受者,可以同时发送多个,以逗号隔开
subject: subject, // 标题
}; mailOptions.text =text;// 文本
var result = {
httpCode: 200,
message: '发送成功!',
data: [],
}
try {
transporter.sendMail(mailOptions, function (err, info) {
if (err) {
result.httpCode = 500;
result.message = err;
callback(result);
return;
}
callback(result);
});
} catch (err) {
result.httpCode = 500;
result.message = err;
callback(result);
}
transport.close(); // 如果没用,关闭连接池
}
第四步:发送邮件接口
在sendEmailApi.js添加如下代码:
var mailer = require('../services/sendEmail.js');
router.post("/SendEmail", function (req, res) {
var email = req.body.email;
var subject = "影琪通知";//标题
var text =undefined;
var html = "<p>你好</p><p>欢迎访问jackson影琪</p><p>点击下面链接进入访问吧:</p><p><a href='https://www.cnblogs.com/jackson-zhangjiang/'>https://www.cnblogs.com/jackson-zhangjiang/</a></p>";;
mailer.emailTo(email, subject, text, html, function (data) {
res.status(data.httpCode).json(data);
})
})
第五步:抛出发送邮件接口
在app.js添加如下代码:
app.use("/api", require("./sendEmailApi.js"));
第六步:web前端调用
采用jquery的方式,使用ajax
sendEmail: function (email, callBack) {
var datajson = {
"email": email
};
$.ajax({
url: 'http://127.0.0.1:3000/api/' + 'SendEmail',
type: "POST",
dataType: "json",
xhrFields: {
withCredentials: true
},
crossDomain: true,
data: datajson,
success: function (data) {
callBack(data);
},
error: function (err) {
console.log(err);
}
});
}
第七步:效果

三,常见问题
1.账号未设置该服务
{ [AuthError: Invalid login - Authentication failed, please open smtp flag first!]
name: 'AuthError',
data: '454 Authentication failed, please open smtp flag first!',
stage: 'auth' }
解决方案:QQ邮箱 -> 设置 -> 帐户 -> 开启服务:POP3/SMTP服务
2.登录认证失败,可能由于smpt授权码/独立密码错误导致
Invalid login - Authentication failed
解决方案:
qq邮箱在测试smtp邮件服务器时,
一,在qq邮箱,设置,账户设置中.开启下smtp.
二,获取授权码.
三,在配置smtp服务器的密码时,注意一定要填你获得的授权码.不要用邮箱登录密码.否则会提示535 Authentication failed错误.
3.权限认证失败,可能由于授权码错误导致,或者发件服务器不对应 我在qq设置的时候就遇到过

解决方案:登录Foxmail,查看发件服务器是什么?我QQ邮箱发件服务器是smtp.qq.com,企业邮箱是:smtp.exmail.qq.com
NodeJs之邮件(email)发送的更多相关文章
- nodejs实现邮件发送
需要安装的node模块 nodemailer 新建项目目录 mail-test 进入这个项目里使用终端初始化package.json(npm init) 安装express和nodemailer并保存 ...
- (转载)JavaWeb学习总结(五十一)——邮件的发送与接收原理
博客源地址:http://www.cnblogs.com/xdp-gacl/p/4209586.html 一. 邮件开发涉及到的一些基本概念 1.1.邮件服务器和电子邮箱 要在Internet上提供电 ...
- JavaWeb学习总结(五十一)——邮件的发送与接收原理
一. 邮件开发涉及到的一些基本概念 1.1.邮件服务器和电子邮箱 要在Internet上提供电子邮件功能,必须有专门的电子邮件服务器.例如现在Internet很多提供邮件服务的厂商:sina.sohu ...
- C#中邮件的发送基本操作
本地配置的邮箱:http://localhost:6080/index.php //邮件的收发需要用到两个类 //1.用来创建一封邮件对象 //1.MailMessage 添加对 usin ...
- 配置 SQL Server Email 发送以及 Job 的 Notification通知功能
配置 SQL Server Email 发送以及 Job 的 Notification通知功能 在与数据库相关的项目中, 比如像数据库维护, 性能警报, 程序出错警报或通知都会使用到在 SQL Ser ...
- 使用Python发送HTML格式的邮件(收到的邮件有发送方才是正解)
发送html格式的和普通文本格式差不多,只是MIMEText(content,"html","utf-8"))与MIMEText(content,"p ...
- java实现简单邮件的发送以及常见问题
java实现简单邮件的发送以及常见问题 最近遇到个需求需要实现发送邮件的功能,以前做发送邮件功能都是有邮箱用户名密码,通过用户名密码连接对应的SMTP服务器来实现邮件的发送.但是这次用公司内部的邮箱, ...
- Java 实现邮件的发送
Java 实现邮件的发送 开发邮箱发送功能必须看邮箱方面的资料 改一些东西 (我的是qq 邮箱哟 开通 POP3 ...
- python selenium2示例 - email发送
前言 在进行日常的自动化测试实践中,我们总是需要将测试过程中的记录.结果等等等相关信息通过自动的手段发送给相关人员.python的smtplib.email模块为我们提供了很好的email发送等功能的 ...
随机推荐
- zabbix监控elasticsearch
1.环境概述 虚拟机系统:CentOS Linux release 7.3.1611 (Core) 宿主机系统:Mac Sierra version 10.12.3 nginx:1.10.3 php: ...
- MySql-两阶段加锁协议
此篇博客主要是讲述MySql(仅限innodb)的两阶段加锁(2PL)协议,而非两阶段提交(2PC)协议,区别如下: 2PL,两阶段加锁协议:主要用于单机事务中的一致性与隔离性. 2PC,两阶段提交协 ...
- ThreadLocal的应用与实现原理
本文对ThreadLocal的分析基于JDK 8. 本文大纲 1. ThreadLocal快速上手 2. ThreadLocal应用场景 3. TheadLocal set与get方法简析 4. Th ...
- 【STM32H7教程】第7章 STM32H7下载和调试方法(IAR8)
完整教程下载地址:http://forum.armfly.com/forum.php?mod=viewthread&tid=86980 第7章 STM32H7下载和调试方法(IAR8) 本 ...
- 前端ps实用小技巧
下面总结了几个日常使用PS的小技巧,希望对大家有所帮助(重点推荐第一个小技巧) 场景一:用ps测量PSD图中的元素宽高间距时,一般是手动使用 测量,但其实是有快捷键的,如下图 首先选中元素相应图层,然 ...
- 《前端之路》之 Javascript 模块化管理的来世今生
目录 第二章 - 04: Javascript 模块化管理的来世今生 一.什么是模块化开发 1-1.模块化第一阶段 1-2.封装到对象 1-3. 对象的优化 二.模块化管理的发展历程 2-1.Comm ...
- 安装Mysql时端口号3306被占用,解决方法
当我们在卸载mysql数据库重新安装的时候,会出现端口号3306被占用的情况 有两种解决方案: 一:可以不使用3306端口,也可以换成别的端口,如3307,3308等等 二:可以打开命令窗口 1.wi ...
- C语言超级搞笑的代码,冷笑话我们程序员也会讲的啊!
百年修得足下点击本文 欢迎来到"C语言基础"专题,今天我们放松一天,不学习知识,来看下大千世界的千奇百怪的C语言代码,你见过那些? 1.关于随机数这回事 这个随机数有点意思哦. 2 ...
- nginx + lua 限制ip地址访问
实验环境:docker + openresty 我限制的5秒钟内允许访问两次效果图: default.conf 代码如下: lua_shared_dict my_limit_count_store ...
- jQuery实现全选、反选和不选功能
HTML 我们的页面上有一个歌曲列表,列出多行歌曲名称,并匹配复选框供用户选择,并且在列表下方有一排操作按钮. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 <ul id=&q ...