利用Node.JS实现邮件发送功能


Posted in Javascript onOctober 21, 2016

第一步、配置篇

首先需要安装nodemailer库

npm install nodemailer//默认会安装最新的版本。

关于这个库的文档参见nodemailer

第二步、库的一些使用介绍

这个库使用方法很简单的。首先是要创建一个用于发送邮件的实例

var transporter = nodemailer.createTransport(transport[, defaults])

transport参数属性

属性太多了就只写一些关键的属性

     port:连接的端口号,一般就是465

     host:你用于发送邮件的服务器的host,比如163的host是stmp.163.com

     auth:这个就是和老版本不一样的地方了。新版本是用一个字面量存储用户名和密码。注意你的邮箱要开启stmp。

     user:用户名

     pass:密码。如果你的163设置了第三方登录密码的话这里要填你的第三方登录密码、

设置好了这些就可以使用啦~这里贴上我的设置

var smtpConfig = {
 host: 'smtp.163.com',
 port: 465,
 auth: {
  user: 'xxxx',
  pass: 'xxxx'
 }
};
var transporter = nodemailer.createTransport(smtpConfig);

第三步、使用篇

现在我们可以使用以下函数进行发送邮件

transporter.sendMail(data[, callback])

data邮件内容

      from 邮件的发件人

      to 邮件的收件人

      subject 主题

      text 邮件是以文本的方式进行发送

      html 邮件内容是html网页效果

      attachments 附件。详细可以看官方文档

callback回调函数

      接受两个参数 errinfo

err

如果失败了就可以打印这个对象看相关信息

info

可以看很多发送状态的信息

      messageID 会返回信息的messageID值,我也不太懂

      accepted 是一个数组,包括服务器接收的内容的地址

      rejected 意义和上面差不多,就是相反的意思

好了说完了我们就可以发送邮件了

var sendmail = function(html){
 var option = {
  from:"sender",
  to:"accepter",
  subject : '来自node的邮件',
  html : html
 }
 transporter.sendMail(option, function(error, response){
  if(error){
   console.log("fail: " + error);
  }else{
   console.log("success: " + response.messageID);
  }
 });
}

sendmail("邮件内容:<br/>这是来自nodemailer发送的邮件");

总结

以上就是利用Node.JS实现邮件发送功能的全部内容,希望本文的内容对大家学习或者使用Node.js能有所帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
漂亮的widgets,支持换肤和后期开发新皮肤(2007-4-27已更新1.7alpha)
Apr 27 Javascript
jquery和ajax的关系详细介绍
Nov 29 Javascript
在百度知道团队中快速审批新成员的js脚本
Feb 02 Javascript
Javascript排序算法之计数排序的实例
Apr 05 Javascript
node.js入门教程迷你书、node.js入门web应用开发完全示例
Apr 06 Javascript
JS+CSS实现鼠标经过弹出一个DIV框完整实例(带缓冲动画渐变效果)
Mar 25 Javascript
学习Bootstrap滚动监听 附调用方法
Jul 02 Javascript
Angular的$http的ajax的请求操作(推荐)
Jan 10 Javascript
Bootstrap table 定制提示语的加载过程
Feb 20 Javascript
微信小程序实现选项卡功能
Jun 19 Javascript
vue-cli+axios实现文件上传下载功能(下载接收后台返回文件流)
May 10 Javascript
Js视频播放器插件Video.js使用方法详解
Feb 04 Javascript
bootstrap中使用google prettify让代码高亮的方法
Oct 21 #Javascript
BootStrap网页中代码显示用法详解
Oct 21 #Javascript
网页瀑布流布局jQuery实现代码
Oct 21 #Javascript
js运动事件函数详解
Oct 21 #Javascript
javascript轮播图算法
Oct 21 #Javascript
使用BootStrap和Metroui设计的metro风格微网站或手机app界面
Oct 21 #Javascript
javascript简易画板开发
Apr 12 #Javascript
You might like
PHP如何编写易读的代码
2007/07/10 PHP
PHP_Cooikes不同页面无法传递的解决方法
2014/03/07 PHP
PHP常见的几种攻击方式实例小结
2019/04/29 PHP
js的回调函数详解
2015/01/05 Javascript
js制作带有遮罩弹出层实现登录注册表单特效代码分享
2015/09/05 Javascript
JS判断是否长按某一键的方法
2016/03/02 Javascript
浅谈JSON.stringify()和JOSN.parse()方法的不同
2016/08/29 Javascript
JS返回只包含数字类型的数组实例分析
2016/12/16 Javascript
jQuery弹出层插件popShow用法示例
2017/01/23 Javascript
JavaScript常用正则验证函数实例小结【年龄,数字,Email,手机,URL,日期等】
2017/01/23 Javascript
如何编写jquery插件
2017/03/29 jQuery
vuejs 单文件组件.vue 文件的使用
2017/07/28 Javascript
JS实现头条新闻的经典轮播图效果示例
2019/01/30 Javascript
解决Layui 表格自适应高度的问题
2019/11/15 Javascript
VUE项目axios请求头更改Content-Type操作
2020/07/24 Javascript
解决nuxt 自定义全局方法,全局属性,全局变量的问题
2020/11/05 Javascript
Python入门及进阶笔记 Python 内置函数小结
2014/08/09 Python
Python实现统计单词出现的个数
2015/05/28 Python
python实现电脑自动关机
2018/06/20 Python
Python多进程写入同一文件的方法
2019/01/14 Python
使用Django连接Mysql数据库步骤
2019/01/15 Python
python3转换code128条形码的方法
2019/04/17 Python
pytorch 获取tensor维度信息示例
2020/01/03 Python
基于python实现操作redis及消息队列
2020/08/27 Python
全面解析HTML5中的标准属性与自定义属性
2016/02/18 HTML / CSS
美国马匹用品和马钉购物网站:State Line Tack
2018/08/05 全球购物
澳大利亚家居用品零售商:Harris Scarfe
2020/10/10 全球购物
JoJo Maman Bébé爱尔兰官网:英国最受欢迎的精品母婴品牌
2020/12/20 全球购物
Java中有几种方法可以实现一个线程?用什么关键字修饰同步方法?stop()和suspend()方法为何不推荐使用?
2015/08/04 面试题
葬礼司仪主持词
2014/03/31 职场文书
《黄山奇石》教学反思
2014/04/19 职场文书
公司运动会策划方案
2014/05/25 职场文书
高中学校对照检查材料
2014/08/31 职场文书
介绍信格式
2015/01/30 职场文书
K8s部署发布Golang应用程序的实现方法
2021/07/16 Golang
关于k8s环境部署mysql主从的问题
2022/03/13 MySQL