【nodemailer】 初试

时间:2022-10-25 19:32:26

【nodemailer】 初试

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>

然而结果却是这样的

【nodemailer】 初试

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

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