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即可收到 邮件

注意

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


  • 2018-04-07 23:35:16

    使用Intent传递对象的两种方式

    Intent 的用法相信你已经比较熟悉了,我们可以借助它来启动活动、发送广播、启动服务等。在进行上述操作的时候,我们还可以在Intent 中添加一些附加数据,以达到传值的效果,比如在FirstActivity 中添加如下代码:

  • 2018-04-10 14:59:59

    JS实现数组去重方法总结(六种方法)

    这篇文章给大家总结下JS实现数组去重方法(六种方法),面试中也经常会遇到这个问题。文中给大家引申的还有合并数组并去重的方法,感兴趣的朋友跟随脚本之家小编一起学习吧

  • 2018-04-13 17:28:33

    jsoup 使用总结4--高级用法之 script js 脚本

    大部分时候,我们使用jsoup解析网页的时候,都是直接找到某一类元素,或者按某种selector查询;具体使用方法可以参考jsoup官网文档 那么你有没有实际操作过,查找script js 脚本呢,因为很多时候页面的内容是根据js动态生成的,或者数据是动态变更;那么这个时候,我们只是获取html页面中script js脚本之间的内容。

  • 2018-04-15 12:56:05

    WebView控件之WebSettings各种配置方法源码总结

    WebSettings用于管理WebView状态配置,当WebView第一次被创建时,WebView包含着一个默认的配置,这些默认的配置将通过get方法返回,通过WebView中的getSettings方法获得一个WebSettings对象,如果一个WebView被销毁,在WebSettings中所有回调方法将抛出IllegalStateException异常。

  • 2018-04-16 07:28:10

    android点击事件,第一次无效,第二次才响应的问题

    今天碰到的问题,android的标题栏一个回退button,每次进入的时候第一次点击无效,一直到第二次点击时才响应,然后把代码copy到系统的回退按钮里面,结果每次都能响应,后面想了想,应该跟焦点有关系