nodejs实现邮箱发送验证码功能

 更新时间:2024年07月17日 08:29:19   作者:前端梭哈攻城狮  
开发个人网站时,注册页面可以使用邮箱验证,于是记录一下如何用nodejs/express服务器实现邮箱发送验证码,不仅可以在邮箱注册时使用,还可以拓展用于各种安全验证,本文给大家介绍了使用nodejs实现邮箱发送验证码功能,需要的朋友可以参考下

1、前言

开发个人网站时,注册页面可以使用邮箱验证,于是记录一下如何用nodejs/express服务器实现邮箱发送验证码,不仅可以在邮箱注册时使用,还可以拓展用于各种安全验证。

2、依赖包

nodejs服务器需要 express,另外就是我们发送邮箱的包 nodemailer  , cors解决跨域用于测试

npm i express nodemailer cors

3、使用qq邮箱获取授权码

1)首先封装 nodemailer.js 文件,添加基本配置,配置前需要得到邮箱类型的 port 和  secure  还有 邮箱stmp授权码。

2)//node_modules/nodemailer/lib/well-known/services.json  可以查看相关的配置,比如这里是qq邮箱,port为465,secure为true。

3)邮箱---设置--账户--POP3/SMTP服务---开启---获取stmp授权码

最终获取到授权码

4、代码实现

1)创建nodemailer.js文件

const nodemailer = require('nodemailer')

let nodeMail = nodemailer.createTransport({
  service: "qq", //类型qq邮箱
  port: 465, //上文获取的port
  secure: true, //上文获取的secure
  auth: {
    user: "779217162@qq.com", // 发送方的邮箱,可以选择你自己的qq邮箱
    pass: "上文获取的stmp授权码", // 上文获取的stmp授权码
  },
});

module.exports = nodeMail

2)创建app.js

//app.js
const express = require("express");
const cors = require("cors");
const nodeMail = require("./nodemailer.js");

const app = express();
app.use(express.static("public"));

app.use(express.json());
app.use(cors());

app.post("/api/email", async (req, res) => {
  const email = req.body.email;
  const code = String(Math.floor(Math.random() * 1000000)).padEnd(6, "0"); //生成6位随机验证码
  //发送邮件
  const mail = {
    from: `"faker前端开发"<779217162@qq.com>`, // 发件人
    subject: "验证码", //邮箱主题
    to: email, //收件人,这里由post请求传递过来
    // 邮件内容,用html格式编写
    html: `
             <p>您好!</p>
             <p>您的验证码是:<strong style="color:orangered;">$[code]</strong></p>
             <p>如果不是您本人操作,请无视此邮件</p>
         `,
  };
  await nodeMail.sendMail(mail, (err, info) => {
    if (!err) {
      res.json({ msg: "验证码发送成功" });
    } else {
      res.json({ msg: "验证码发送失败,请稍后重试" });
    }
  });
});

app.listen(3123, () => {
  console.log("服务开启成功 , http:www.localhost:3123");
});

3)创建/public/index.html文件

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>发送邮件</title>
  </head>
  <body>
    <button onclick="sendMail()">发送邮件</button>
    <script>
      async function sendMail() {
        console.log("发送邮件");
        const res = await fetch("/api/email", {
          method: "POST",
          headers: {
            "Content-Type": "application/json",
          },
          body: JSON.stringify({
            email: "991584844@qq.com",
          }),
        });
        const data = await res.json();
        console.log(data);
      }
    </script>
  </body>
</html>

目录结构为:

5、发送效果

发送邮件: 779217162@qq.com ===>  991584844@qq.com

6、源码地址

github: https://github.com/ArcherNull/Archer/tree/main/nodejs-mailer

以上就是nodejs实现邮箱发送验证码功能的详细内容,更多关于nodejs邮箱发送验证码的资料请关注脚本之家其它相关文章!

相关文章

  • Node.js中的WebSocket底层实现

    Node.js中的WebSocket底层实现

    WebSockets是基于HTTP的双向通信协议,允许客户端和服务器之间实现实时、持久的数据交换,本文详细介绍了使用JavaScript和Node.js创建WebSockets服务器和客户端的过程,感兴趣的可以了解一下
    2024-10-10
  • node.js 模块和其下载资源的镜像设置的方法

    node.js 模块和其下载资源的镜像设置的方法

    这篇文章主要介绍了node.js 模块和其下载资源的镜像设置的方法,在设置淘宝镜像共有三种方法,每种方法通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2018-09-09
  • node.js中的http.response.addTrailers方法使用说明

    node.js中的http.response.addTrailers方法使用说明

    这篇文章主要介绍了node.js中的http.response.addTrailers方法使用说明,本文介绍了http.response.addTrailers的方法说明、语法、接收参数、使用实例和实现源码,需要的朋友可以参考下
    2014-12-12
  • node.js mongoose index索引操作

    node.js mongoose index索引操作

    在 Mongoose 中,索引(Index)是一种用于提高查询性能的数据结构,它可以加速对数据库中文档的检索操作,本文给大家介绍
    node.js mongoose index索引操作
    ,感兴趣的朋友一起看看吧
    2023-12-12
  • Nodejs实现的一个静态服务器实例

    Nodejs实现的一个静态服务器实例

    这篇文章主要介绍了Nodejs实现的一个静态服务器实例,本文实现的静态服务器实例包含cache功能、压缩功能等,需要的朋友可以参考下
    2014-12-12
  • 如何通过node.js来写接口详解

    如何通过node.js来写接口详解

    最近研究了一下nodejs写接口,发现接口并不难写,这篇文章主要给大家介绍了关于如何通过node.js来写接口的相关资料,文中通过实例代码和图文介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • nodejs个人博客开发第三步 载入页面

    nodejs个人博客开发第三步 载入页面

    这篇文章主要为大家详细介绍了nodejs个人博客开发的载入页面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • Nodejs使用SQL模糊查询的过程详解

    Nodejs使用SQL模糊查询的过程详解

    最近在改一个比较久的项目,是使用nodejs写的,但是对于长期写java的后端开发来说,还是有点难维护,不过不改bug的话,就需要重新开发,所以本文介绍了NodeJs如何使用SQL模糊查询,需要的朋友可以参考下
    2024-07-07
  • 基于NodeJS的前后端分离的思考与实践(六)Nginx + Node.js + Java 的软件栈部署实践

    基于NodeJS的前后端分离的思考与实践(六)Nginx + Node.js + Java 的软件栈部署实践

    关于前后端分享的思考,我们已经有五篇文章阐述思路与设计。本文介绍淘宝网收藏夹将 Node.js 引入传统技术栈的具体实践。
    2014-09-09
  • Node.js操作Firebird数据库教程

    Node.js操作Firebird数据库教程

    这篇文章主要为大家分享了Node.js操作Firebird数据库教程,思路清晰便于大家理解,感兴趣的小伙伴们可以参考一下
    2016-03-03

最新评论