node.js使用Nodemailer发送邮件

引言


常常看到一些网站有邮箱获取验证码验证注册或者修改密码等,今天也来了解一下在nodejs + express怎么发送电子邮件。使用模块Nodemailer。这里以qq邮箱举例子。

安装模块


npm install Nodemailer --save

创建一个SMTP客户端配置


//引入模块 nodemailer
 const nodemailer = require('nodemailer')

 const config = {
    // 163邮箱 为smtp.163.com
    host: 'smtp.qq.com',//这是qq邮箱
    //端口
    port: 465,
    auth: {
        // 发件人邮箱账号
        user: '651762920@qq.com', 
        //发件人邮箱的授权码 这里可以通过qq邮箱获取 并且不唯一
        pass: 'xxxxxxxxx'  
    }
 }

创建一个SMTP客户端配置对象


即把上述的客户端配置作为nodemailer.createTransport方法参数传递进去即可

const transporter = nodemailer.createTransport(config)

创建一个收件人对象

即填写发件人和收件人的一些信息,以及发送的内容

 const mail = {
    // 发件人 邮箱  '昵称<发件人邮箱>'
    from: '车神-黄杰<651762920@qq.com>',
    // 主题
    subject: '激活验证码',
    // 收件人 的邮箱 可以是其他邮箱 不一定是qq邮箱
    to: 'xxxxxx',
    // 内容
    text: `您的激活验证码为:666888, 请24小时内有效,请谨慎保管。` ,
    //这里可以添加html标签
    html: '<a href="https://www.cnblogs.com/HJ412/">车神-黄杰</a>'
 }

发送邮件 调用 transporter.sendMail(mail, callback)


@params mail 收件人配置对象
@params callback 回调函数

 function sendEmail(mail){
    transporter.sendMail(mail, function(error, info){
        if(error) {
            return console.log(error);
        }
        transporter.close()
        console.log('mail sent:', info.response)
    })
 }

获取授权码

打开pc端qq邮箱,点击设置,再点击帐户

往下拉 可开启POP3/SMTP服务 根据提示即可获取qq邮箱授权码

完整代码

我把这些代码封装成一个nodemailer.js文件

 //引入模块 nodemailer
 const nodemailer = require('nodemailer')

 const config = {
    // 163邮箱 为smtp.163.com
    host: 'smtp.qq.com',//这是qq邮箱
    //端口
    port: 465,
    auth: {
        // 发件人邮箱账号
        user: '651762920@qq.com', 
        //发件人邮箱的授权码 这里可以通过qq邮箱获取 并且不唯一
        pass: 'etrdgnwpniclsbfih'  
    }
 }

 const transporter = nodemailer.createTransport(config)

  const mail = {
    // 发件人 邮箱  '昵称<发件人邮箱>'
    from: '车神-黄杰<651762920@qq.com>',
    // 主题
    subject: '激活验证码',
    // 收件人 的邮箱 可以是其他邮箱 不一定是qq邮箱
    to: '1928611412@qq.com',
    // 内容
    text: `您的激活验证码为:${checkCode}, 请24小时内有效,请谨慎保管。` ,
    //这里可以添加html标签
    html: '<a href="https://www.cnblogs.com/HJ412/">车神-黄杰</a>'
 }

 transporter.sendMail(mail, function(error, info){
    if(error) {
        return console.log(error);
    }
    transporter.close()
    console.log('mail sent:', info.response)
 })

运行 nodemailer.js即可收到 邮件

注意
有时候发送成功,但收件人收不到邮件,可能因为网络问题,也有可能对方把它作为垃圾邮件了,在对方的垃圾邮箱可查找发送的邮箱。不要拿我的授权码以及邮箱测试,因为我的授权码随时会变。

nodemailer.js

// node发送邮件
const nodemailer = require('nodemailer')
const express = require('express');
const app = express();
app.all('*', function (req, res, next) {
    if (!req.get('Origin')) return next();
    res.set('Access-Control-Allow-Origin', '*');
    res.setHeader("Access-Control-Allow-Methods", "GET, PUT, OPTIONS, POST");
    res.set('Access-Control-Allow-Headers', 'X-Requested-With, Content-Type');
    if ('OPTIONS' == req.method) return res.send(200);
    next();
});
// 创建一个SMTP客户端配置
const config = {
    // 163邮箱 为smtp.163.com
    host: 'smtp.qq.com',//这是qq邮箱
    //端口
    port: 465,
    auth: {
        // 发件人邮箱账号
        user: 'xxxxxxxxxx@qq.com',
        //发件人邮箱的授权码 这里可以通过qq邮箱获取 并且不唯一
        pass: 'xxxxxxxxxxxxx'

    }
}
// 创建一个SMTP客户端配置对象
const transporter = nodemailer.createTransport(config)
// 创建一个收件人对象
const mail = {
    // 发件人 邮箱  '昵称<发件人邮箱>'
    from: "what's up<2806275118@qq.com>",
    // 主题
    subject: '激活验证码',
    // 收件人 的邮箱 可以是其他邮箱 不一定是qq邮箱
    to: '3040114887@qq.com',
    // 内容
    text: `您的激活验证码为:666888, 请24小时内有效,请谨慎保管。`,
    //这里可以添加html标签
    // html: '<a href="https://www.cnblogs.com/HJ412/">车神-黄杰</a>'
}
// 发送邮件 调用
// transporter.sendMail(mail, callback)
function sendEmail(mail) {
    transporter.sendMail(mail, function (error, info) {
        if (error) {
            return console.log(error);
        }
        transporter.close()
        console.log('mail sent:', info.response)
    })
}
app.post('/sendEmail', (req, res) => {
    console.log('发送')
    sendEmail(mail)
})
app.listen(3000, () => {
    console.log('监听3000端口')
})

sendEmail.vue

<template>
  <div>
    <el-button @click="send">按钮</el-button>
  </div>
</template>

<script>
export default {
  data() {
    return {}
  },
  methods: {
    send() {
      this.$post('/app/sendEmail')
        .then((res) => {
          console.log(res, 'res')
        })
        .catch((err) => {
          console.log(err, 'err')
        })
    },
  },
}
</script>

vue.config.js

module.exports = {
    lintOnSave: false,
    devServer: {
        //     // 设置主机地址
        host: 'localhost',
        disableHostCheck: true,
        //     // 设置默认端口
        port: 8080,
        open: false, //项目启动时是否自动打开浏览器,我这里设置为false,不打开,true表示打开
        proxy: {
            '/app': {//代理api
                target: "http://localhost:3000",//测试api地址
                changeOrigin: true,//是否跨域
                ws: false, // proxy websockets
                pathRewrite: {//重写路径
                    "^/app": ''
                }
            }
        }
    },
}
posted @   崛起崛起  阅读(846)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示