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

注意

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


  • 2020-01-07 10:06:00

    vue重定向beforeRouterEnter与replace的使用

    一个登录页面,只有第一次才会出现,一旦出现过,以后再也不会出现,即使是输入该页面的url也不会跳转到该页面,只会跳转到指定的其他页面;

  • 2020-01-07 10:14:07

    vue强制刷新组件 销毁和重建

    很多时候,通过重置数据将页面重置时,子组件可以提供重置的方法,或者提供props重置自己的状态。但是相对麻烦,那可以使用强制刷新来实现刷新组件。

  • 2020-01-07 10:17:42

    vue钩子函数beforeRouteUpdate没有反应

    由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。 可以访问组件实例 `this`

  • 2020-01-08 13:23:24

    vue 中使用eventbus

    为了提高组件的独立性和重用性,父组件会通过props向下传数据给子组件,当子组件又事情要告诉父组件时用通过$emit事件告诉父组件,如此确保每个组件都是独立在相对隔离的环境中运行,可以大幅度提高组件的可维护性

  • 2020-01-08 13:30:30

    vue中eventbus被多次触发(vue中使用eventbus踩过的坑)

    一开始的需求是这样子的,我为了实现两个页面组件之间的数据传递,假设我有页面A,点击页面A上的某一个按钮之后,页面会自动跳转到页面B,同时我希望将页面A上的某一些参数携带过去给页面B。 然后我就想,这不就是不同组件之间的数据传递问题而已吗?直接用bus 巴士事件来传递数据不就行了吗。于是,我就很愉快地进行了。关于vue中的eventbus的使用,我之前在一篇vue中的数据传递中有提到过。

  • 2020-01-08 22:03:07

    修改MAC系统下默认PHP版本

    今天在使用mac时遇到了一个问题,因为需要composer拉取laravel5.6,但是提示我php版本过低,但是我本人使用的是集成环境MAMP,已经切换了php7.2的版本,这个为什么没有生效呢?经检查是因为composer检测得是mac下环境变量生效的php版本