node.js使用Nodemailer发送邮件

2021-01-21 13:52:36

参考地址 node.js使用Nodemailer发送邮件

node.js使用Nodemailer发送邮件

注意事项   service: 'qq', // 使用了内置传输发送邮件 查看支持列表:https://nodemailer.com/smtp/well-known/



引言

  • 常常看到一些网站有邮箱获取验证码验证注册或者修改密码等,今天也来了解一下在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即可收到 邮件

注意

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


  • 2019-12-23 14:54:03

    RPC, REST ,GraphQL区别比较优劣

    其实在使用和学习的过程中,有很多文章都对比过它们的异同,但是大部分文章并没有从一个相对客观的角度来对比,更多是为了突显一个的优点而刻意指出另外一个的缺点。这让我想到一句话,脱离业务情景谈技术就是耍流氓。

  • 2019-12-23 23:38:59

    vue-apollo的多客户端的用法

    vue-apollo的多客户端的用法以及apollo.js的配置 关于如何安装和如何使用,这篇文章就先暂时不介绍了,如果不清楚就看我另一篇关于vue-apollo的用法 在做项目中,有时候后端的接口是按模块功能去划分的,那么请求的地址就会不同,关于vue-apollo的多客户端配置如下

  • 2019-12-27 08:40:55

    align-self和align-items的区别

    align-items在伸缩容器上使用它,伸缩容器内部所有的元素都一致地受制于align-items的值。 但是有些时候,我们希望伸缩容器内部某个元素在侧轴上的排列方式有所差异。此时就不能使用 align-items,因为align-items作用于整体。我们希望作用于部分。这就是align-self的发挥场地。

  • 2019-12-29 15:01:37

    修改laravel分页的样式

    首先获取到数据,paginate方法 能够自动判定当前页面正确的数量限制和偏移数。默认情况下,当前页数由HTTP 请求所带的 ?page 参数来决定。当然,该值由 Laravel 自动检测,并自动插入由分页器生成的链接。

  • 2019-12-29 15:05:57

    php 数组分页 array_slice()函数用法

    今天用到一个函数,非常好用,分享给大家 array_slice() -从数组中取出一段 也就是说用这个函数可以和sql语句一样实现分页,原理是将查询出的数组,取出从指定下标开始到指定长度的数组