第八篇:node简单使用 nodemailer+node-schedule 实现定时发送邮件

该篇内容:简单的书写一个 sendmaildemo.js ,借助 nodemailer + node-schedule 来实现定时的发送邮件

前提条件:是需要获取邮箱的 IMAP/SMTP 服务授权码,以qq邮箱为例子,具体操作步骤截图如下

登录邮箱-->设置-->第三方服务-->生成授权码。将 获取到的 授权码 放到下面的代码 pass 处。

准备好了之后,接下来可以书写demo了

1. npm 安装 nodemailer、node-schedule

npm install node-schedule -D
npm install nodemailer -D

2. 如下代码

部分模块解释:

user: 个人的邮箱,也就是需要获取 IMAP/SMTP 服务授权码的邮箱

pass: 不是邮箱登录的密码,而是 上面获取到的 IMAP/SMTP 服务授权码。

该例子的定时任务是 每天的 18:30 执行一次。

其他的都有注释。

const nodemailer = require('nodemailer');
var schedule = require("node-schedule");

let transporter = nodemailer.createTransport({
    service: 'qq', // qq服务器
    secure:true, // 安全连接
    auth:{
        user:'XXXXXXXX@qq.com', //发送者邮箱
        pass:'XXXXXX'  // 发送者邮箱授权码,不是登录或者独立密码,是你设置的smtp授权密码
    }
});

let mailOptions = {
    from:'"测试"<XXXXXXXX@qq.com>', //发送者邮箱
    to:'xxxxxxx@qq.com;', //接受者邮箱,可以设置多个,以;隔开即可
    subject:'恭喜获得计算机高级证书', //邮件主题
    text:'计算机高级考试证书!', //信箱里邮件列表时,此邮件显示的内容说明
    html:'<b>企业培训证书!</b><br/><img src="cid:00001" alt="证书图片" />', //邮件内容
    watchHtml: '<b>企业</b> 培训证书!', // Apple Watch specific HTML body 苹果手表指定HTML格式
    //附件 filename在邮件中附件显示的名字,content附件的内容,contentType附件的类型,cid附件的id
    //关于附件的更多用法以及属性说明,参考 https://nodemailer.com/message/attachments/
    attachments: [
        // String attachment
        {
            filename: 'notes.txt',
            content: 'Some notes about this e-mail',
            contentType: 'text/plain' // 可选,会检测文件名
        },
        // Binary Buffer attchment
        {
            filename: 't1.png',
            content: '',
            cid: '00001'  // id唯一
        }
    ]
};

function sendMailTask() {
    transporter.sendMail(mailOptions,(err,info)=>{
        if(err){
            console.log(err);
        }
        else{
            console.log(info);
        }
    });
}
// 定时任务
schedule.scheduleJob({ hour: 18, minute: 30 }, function () {
    console.log("启动任务:" + new Date());
    sendMailTask()
  });

3. 启动该服务,可输入如下的指令:

node sendmaildemo.js

4.个人测试的时候,可以将定时任务调整为自己需要的时间即可。感谢支持。

上一篇:第七篇:VUE 使用 Echarts 画时钟钟表

下一篇:第九篇 Elementui 树形表格多选问题-多级树形表格懒加载复选框勾选问题

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值