nodemailer 是什么?

简单的讲nodemailer就是用来发送邮件的。最近的一个项目需要向客户的注册邮箱发送验证连接,研究了一下.

刚开始我以为nodemailer还可以用来接收邮件,看了好一会儿文档都没发现怎么接收邮件,结果弄错了

nodemailer 有哪些功能

  • 在支持纯文本的基础上还支持发送html格式的邮件内容
  • 支持markdown语法编辑的邮件
  • 支持发送文件附件
  • 支持多收件人,支持抄送,密送

nodemailer的插件

内嵌的插件

  • nodemailer-smtp-transport 使用SMTP发送邮件

    使用该插件可以配置SMTP服务,很多手机上都有一个接受邮件服务的APP,里面可以设置多个邮件账户,然后该APP就可以代你收发邮件,不过前提是你的账户开通了SMTP服务。如QQ邮箱可以 设置->账户里面设置开通SMTP服务
  • nodemailer-direct-transport 直接发送邮件

    虽然是直接发,看文档上的例子,连密码都没设置就发了,确实我用的网易邮箱不用填密码就发了,不过使用QQ邮箱就报错。不过对于这点不用深究

作为依赖安装的插件

  • nodemailer-smtp-pool nodemailer-smtp-transport的升级版,使用了连接池
  • nodemailer-sendmail-transport该插件使得nodemailer可以通过命令行发送邮件
  • 官网里面介绍的另外几个是为和外部的API接口对接而开发的,用不到的话就不用在意*

可选的插件

我的测试

//Created by yyrdl on 2015/10/2.
var nodemailer = require('nodemailer');
var smtpPool=require("nodemailer-smtp-pool");
var tool=require("./readFile");
var options={
"service":"QQ",
"auth":{
"user":"xxxxx@qq.com",//你的账号
"pass":"xxxxx"//你账号的密码
},
"maxConnections":10,//最大连接数
"secure":true //use SSL
};
var transporter = nodemailer.createTransport(smtpPool(options)); tool.readFile("./index.html",function(err,res){
if(err){ }else{
transporter.sendMail({
from:'xxxxx@qq.com',//这个应该和上面那个一致
to: 'bbbbbbb@163.com',
subject: 'hello',
html: res//邮件是html格式,至于markdown或者mustache,或者Express Handlebars,去看相关文档即可
},function(err,res){
if(err){
console.log(err);
}else{
console.log(res);
}
});
}
});

由于可以发送html格式的内容,猜测邮件的显示框是一个iframe或者frame ,那这样我是不是可以引用外部样式了呢?比如说bootstrap _ ,好吧试试

PS:options中的service可选值可以参考Nodemailer Well-Known

 <!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8"/>
<link rel="stylesheet" type="text/css" href="http://libs.baidu.com/bootstrap/3.3.0/css/bootstrap.min.css"/>
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<script src="http://libs.baidu.com/bootstrap/3.3.0/js/bootstrap.min.js"></script>
<style>
.s_c{
margin-top:20px;
}
</style>
<script>
setTimeout(function(){
alert("k");
},3000);
</script>
</head>
<body> <div class="container s_c" >
<h1>Example Heading <span class="label label-default">Label</span></h1>
</div>
</body>
</html>

然而结果却是这样的



第一文字并没有居中,而且Label也不是浅色,所以猜测应该是不可以引入外部文件的,标签页禁用,并且禁用javascript,然而使用style添加的样式还是可以的

---记录,分享。转载请注明出处!

【nodemailer】 初试的更多相关文章

  1. 使用nodemailer发送邮件

    今天闲来无事,一时兴起看了下如果使用javascript来发送邮件.经过调研发现,nodeJs可以实现这个功能. 具体的步骤如下: 1.安装依赖 npm install nodemailer -g ( ...

  2. nodemailer 发邮件

    var transporter = nodemailer.createTransport({//v1.0 above do not use 'SMTP' as first param host: &q ...

  3. caffe初试(一)happynear的caffe-windows版本的配置及遇到的问题

    之前已经配置过一次caffe环境了: Caffe初试(一)win7_64bit+VS2013+Opencv2.4.10+CUDA6.5配置Caffe环境 但其中也提到,编译时,用到了cuda6.5,但 ...

  4. 初试Nodejs——使用keystonejs创建博客网站2(修改模板)

    上一篇(初试Nodejs——使用keystonejs创建博客网站1(安装keystonejs))讲了keystonejs的安装.安装完成后,已经具备了基本的功能,我们需要对页面进行初步修改,比如,增加 ...

  5. nodemailer实现node发送邮件

    作为一个前端er,利用node独立做一些全栈小项目,是很有效率和必要的. 需要: 做一个活动报名页面,用户填好的表单需要被工作人员收到,一想到把数据存数据库,还需要给工作人员写一个管理页面就觉得很麻烦 ...

  6. 项目中初试PHP单元测试

    只能叫初试,前面虽然做了一些PHPUnit与团队所用框架的整合,但在整个团队还没有人可以主动推动这个事情,而作为Leader最重要的一种能力应该是"让正确的事情发生",所以今天开始 ...

  7. VPS -Digital Ocean -初试以及VPN的搭建

    首先恭喜你找到这篇博客,它会带你走出困境. 题外话(请忽略):一直以来想搞一个VPS,终于在自己的刺激下试了一下Digital Ocean,还没有使用很长时间不做太多评论,唯一给我的感觉是各种操作还算 ...

  8. 初试微信小程序

    2016年11月3日,微信小程序终于公测了,大家可以正式开发了.早在这之前,应公司要求,和同事就早早的试了一下微信小程序的开发,特此记录一下: 微信官方小程序文档:https://mp.weixin. ...

  9. nodejs & nodemailer

    nodejs & nodemailer https://www.npmjs.com/package/nodemailer 上面的連接裏面 有有一個例子: 可以直接拿來用: 安裝依賴,在pack ...

随机推荐

  1. C/C++语言中#的神奇作用:把宏参数字符串化/贴合宏参数

    宏中"#"和"##"的用法 一.一般用法   我们使用#把宏参数变为一个字符串,用##把两个宏参数贴合在一起. #define STR(s)      #s # ...

  2. C++ “读取位置 0x****** 时发生访问冲突”的可能原因

    转自:http://shansun123.iteye.com/blog/680066 这种错误的意思一般是指访问了不属于自己的内存空间,出现这种错误有几种原因: 1.给一个数组分配了比较小的内存空间, ...

  3. Android Studio Error2

    ECLIPSE ANDROID PROJECT IMPORT SUMMARY ====================================== Ignored Files: ------- ...

  4. js 如何将无限级分类展示出来

    这个需要运用递归. 案例:将数据以 ul li ul li形式展现在div中. <div id="div"></div> 数据格式为json: var da ...

  5. 在javascript中关于submit和button提交表单区别

    submit是button的一个特例,也是button的一种,它把提交这个动作自动集成了,submit和button,二者都以按钮的形式展现,看起来都是按钮,所不同的是type属性和处发响应的事件上. ...

  6. C#_delegate - Pair<T> & 简单顺序逆序 & 方法委托(在Pair类下)&枚举类型 混搭使用

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  7. JQuery实现页面Loading效果

    第一步:添加遮罩层和LOADING层 <div class="overlay"></div><div id="AjaxLoading&quo ...

  8. Java设计模式06:常用设计模式之适配器模式(结构型模式)

    1. Java之适配器模式(Adapter Pattern) (1)概述:    将一个类的接口转换成客户希望的另外一个接口.Adapter模式使得原本由于接口不兼容而不能一起工作的那些类,可以在一起 ...

  9. 第二次作业第3题_JH

    3.完成小组的“四则运算”项目的需求文档(使用Markdown写文档),尝试同组成员在各自PC上修改同一文档后,如何使用Git命令完成GitHub上的文档的更新,而不产生冲突.并验证GitHub上的文 ...

  10. swift switch语句

    switch选择 1)case多条件匹配:条件之间用逗号隔开 用三个点表示范围:…,..<:表示不包含上边界 var tand = 1 switch tand{    case 0:       ...