NodeJs之邮件(email)发送

一,介绍与需求

1.1,介绍

1,Nodemailer简介

Nodemailer是一个简单易用的Node.js邮件发送插件

github地址

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

在settingConfig.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)发送的更多相关文章

  1. nodejs实现邮件发送

    需要安装的node模块 nodemailer 新建项目目录 mail-test 进入这个项目里使用终端初始化package.json(npm init) 安装express和nodemailer并保存 ...

  2. (转载)JavaWeb学习总结(五十一)——邮件的发送与接收原理

    博客源地址:http://www.cnblogs.com/xdp-gacl/p/4209586.html 一. 邮件开发涉及到的一些基本概念 1.1.邮件服务器和电子邮箱 要在Internet上提供电 ...

  3. JavaWeb学习总结(五十一)——邮件的发送与接收原理

    一. 邮件开发涉及到的一些基本概念 1.1.邮件服务器和电子邮箱 要在Internet上提供电子邮件功能,必须有专门的电子邮件服务器.例如现在Internet很多提供邮件服务的厂商:sina.sohu ...

  4. C#中邮件的发送基本操作

    本地配置的邮箱:http://localhost:6080/index.php //邮件的收发需要用到两个类   //1.用来创建一封邮件对象     //1.MailMessage 添加对 usin ...

  5. 配置 SQL Server Email 发送以及 Job 的 Notification通知功能

    配置 SQL Server Email 发送以及 Job 的 Notification通知功能 在与数据库相关的项目中, 比如像数据库维护, 性能警报, 程序出错警报或通知都会使用到在 SQL Ser ...

  6. 使用Python发送HTML格式的邮件(收到的邮件有发送方才是正解)

    发送html格式的和普通文本格式差不多,只是MIMEText(content,"html","utf-8"))与MIMEText(content,"p ...

  7. java实现简单邮件的发送以及常见问题

    java实现简单邮件的发送以及常见问题 最近遇到个需求需要实现发送邮件的功能,以前做发送邮件功能都是有邮箱用户名密码,通过用户名密码连接对应的SMTP服务器来实现邮件的发送.但是这次用公司内部的邮箱, ...

  8. Java 实现邮件的发送

                                             Java 实现邮件的发送 开发邮箱发送功能必须看邮箱方面的资料 改一些东西  (我的是qq 邮箱哟   开通 POP3 ...

  9. python selenium2示例 - email发送

    前言 在进行日常的自动化测试实践中,我们总是需要将测试过程中的记录.结果等等等相关信息通过自动的手段发送给相关人员.python的smtplib.email模块为我们提供了很好的email发送等功能的 ...

随机推荐

  1. 【bzoj 3309 】 DZY Loves Math

    Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007)=1, f(1)=0.给定正整数a,b,求 ...

  2. CF_229E_Gift_概率DP+组合数学

    CF_229E_Gift_概率DP+组合数学 题目描述: 很久很久以前,一位老人和他的妻子住在蔚蓝的海边.有一天,这位老人前去捕鱼,他捉到了一条活着的金鱼.鱼说:“噢,老渔人!我祈求你放我回到海里,这 ...

  3. BZOJ_1864_[Zjoi2006]三色二叉树_树形DP

    BZOJ_1864_[Zjoi2006]三色二叉树_树形DP 题意: 分析:递归建树,然后DP,从子节点转移. 注意到红色和蓝色没有区别,因为我们可以将红蓝互换而方案是相同的.这样的话我们只需要知道当 ...

  4. 前端学习笔记之CSS选择器

    阅读目录 一 基本选择器 二 后代选择器.子元素选择器 三 兄弟选择器 四 交集选择器与并集选择器 五 序列选择器 六 属性选择器 七 伪类选择器 八 伪元素选择器 九 CSS三大特性 一 基本选择器 ...

  5. shell与export命令

    围绕以下几个问题来学习export命令: 1.什么是export命令? 2.为什么要用export命令? 3.怎么使用export命令? 1.什么是export命令? ♦ 用户登录到Linux系统后, ...

  6. 使用Entity Framework Core访问数据库(Oracle篇)

    前言 哇..看看时间 真的很久很久没写博客了 将近一年了. 最近一直在忙各种家中事务和公司的新框架  终于抽出时间来更新一波了. 本篇主要讲一下关于Entity Framework Core访问ora ...

  7. 兄弟俩畅游Tomcat城市的SpringMVC科技园区

    Tomcat城市 Tomcat这座城市的历史相当悠久了,经历过几次大的变迁后,呈现出非常明显的地域特征. 从城市往西走,过了城乡结合部以后,可以说是满目疮痍.一片破败,这就是Servlet地区,这座城 ...

  8. unison+inotify的Web目录同步方案

    1.在Linux下做WEB目录文件同步 一般有如下几种方式: ----------------------------------------------- 1)       nfs实现web数据共享 ...

  9. Thymeleaf【快速入门】

    前言:突然发现自己给自己埋了一个大坑,毕设好难..每一个小点拎出来都能当一个小题目(手动摆手..),没办法自己选的含着泪也要把坑填完..先一点一点把需要补充的知识学完吧.. Thymeleaf介绍 稍 ...

  10. Web前端-Vue.js必备框架(五)

    Web前端-Vue.js必备框架(五) 页面组件,商品列表组件,详情组件,购物车清单组件,结算页组件,订单详情组件,订单列表组件. vue-router 路由 vuex 组件集中管理 webpack ...