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发送等功能的 ...
随机推荐
- C++11中map的用法
最全的c++map的用法 1. map最基本的构造函数:map<string ,int>mapstring; map<int,string >mapint;map<sri ...
- BZOJ_1251_序列终结者
BZOJ_1251_序列终结者 [问题描述] 给定一个长度为N的序列,每个序列的元素是一个整数(废话).要支持以下三种操作: 1. 将[L,R]这个区间内的所有数加上V. 2. 将[L,R]这个区间翻 ...
- Https协议与HttpClient的实现
一.背景 HTTP是一个传输内容有可读性的公开协议,客户端与服务器端的数据完全通过明文传输.在这个背景之下,整个依赖于Http协议的互联网数据都是透明的,这带来了很大的数据安全隐患.想要解决这个问题有 ...
- MIP 技术交流分享(3月15日)
3月15日下午,MIP 团队工程师与58赶集的 Web 前端工程师进行了一次面对面的技术交流. 在这次交流中,MIP 工程师主要分享了 MIP 技术原理,MIP 加速原理,以及 MIP 为开发者提供的 ...
- asp.net core系列 55 IS4使用Identity密码保护API
一.概述 OAuth 2.0资源(web api)所有者密码授权,允许客户端(Client项目)向令牌服务(IdentityServer项目)发送用户名和密码,并获取代表该用户的访问令牌.在官方文档中 ...
- 在阿里云服务器windows server2012r iis上部署.net网站
先说一堆废话:之前在阿里云上租了一个服务器,也配置了相关的环境,然后准备把自己手上的一个小网站挂上去,就按照我的上篇博客记载的方法把发布好的网站发布到服务器的iis上,结果发布之后死活访问不了,始终显 ...
- Java实现简易联网坦克对战小游戏
目录 介绍 本项目的Github地址 基础版本 游戏的原理, 图形界面(非重点) 游戏逻辑 网络联机 客户端连接上服务器 定义应用层协议 TankNewMsg TankMoveMsg MissileN ...
- 如何只在IE上加载CSS样式表
前言:IE一直是特殊的一个浏览器,我们可以使用一些方法来指定样式表只在IE浏览器下被加载. IE9以及低于IE9版本 : 可以使用条件注释语句来加载特定于ie的样式表.如下所示,使用外部css3样式表 ...
- HTML 练习实现鼠标移到用户图像展示更多信息
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- postgreSQL 玩转josnb (长期更新)
json和jsonb的操作符 jsonb额外操作符 json创建函数 json处理函数 函数 返回类型 描述 示例 结果 json_array_length(json) jsonb_array_len ...