如何通过JavaScript给朋友发送请帖(即发送邮件)

1.邮件方法封装----记得先安装nodemailer

const nodemailer = require('nodemailer'); //引入模块
let transporter = nodemailer.createTransport({
    //node_modules/nodemailer/lib/well-known/services.json  查看相关的配置,如果使用qq邮箱,就查看qq邮箱的相关配置
    service: 'qq', //类型qq邮箱
    port: 465,
    secure: true, // true for 465, false for other ports
    auth: {
        user: '555554540@qq.com', // 发送方的邮箱
        pass: 'pn5zgafvkdtvnbahc' // smtp 的授权码
    }
});
//pass 不是邮箱账户的密码而是stmp的授权码(必须是相应邮箱的stmp授权码)
//邮箱---设置--账户--POP3/SMTP服务---开启---获取stmp授权码

function sendMail(mail, {text="玉林路扛把子",html=''}, call) {
    // 发送的配置项
    let mailOptions = {
        from: '玉林路扛把子', // 发送方
        to: mail, //接收者邮箱,多个邮箱用逗号间隔
        subject: text, // 标题
        text: text, // 文本内容
        html: html, //页面内容
        // attachments: [{//发送文件
        //      filename: 'index.html', //文件名字
        //      path: './index.html' //文件路径
        //  },
        //  {
        //      filename: 'sendEmail.js', //文件名字
        //      content: 'sendEmail.js' //文件路径
        //  }
        // ]
    };

    //发送函数
    transporter.sendMail(mailOptions, (error, info) => {
        if (error) {
            call(false)
        } else {
            call(true) //因为是异步 所有需要回调函数通知成功结果
        }
    });

}

module.exports = {
    sendMail
}

2调用方法

 async function timeout() {
        return new Promise((resolve, reject) => {
            Email.sendMail(email, info, (state) => {
                resolve(state);
            })
        })
    }
    await timeout().then(state => {
        let message = msg.error("发送失败")
        if (state) {
            message = msg.success('发送成功',"发送成功")
        } else {

        }
        return ctx.body=  message
    })

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玉林路扛把子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值
>