如何利用node實現發(fā)送QQ郵箱驗證碼
更新時間:2022年04月14日 14:15:36 作者:菜鳥入坑
我們在開發(fā)網站時,發(fā)送驗證碼的功能是必定會遇到的,下面這篇文章主要給大家介紹了關于如何利用node實現發(fā)送QQ郵箱驗證碼的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
開通QQ郵箱POP3/SMTP服務
登錄QQ郵箱網址,進入設置選擇賬戶tab頁翻到最低下開啟此服務

獲取qq郵箱授權碼

搭建node接口服務
思路
- 創(chuàng)建index.js文件
- 安裝connect、body-parser、nodemailer模塊
- 編寫引入connect框架
- 編寫引入bodyParser模塊
- 引入nodemailer模塊
開始安裝插件
使用cmd命令提示或者Git一次執(zhí)行以下安裝命令

開始編寫index.js文件程序
引入各個模塊
let connect = require('connect'), // 引入connect模塊
bodyParser = require('body-parser'), // 引入body-parser解析模塊
nodemailer = require('nodemailer'); // 引入nodemailer模塊聲明并定于發(fā)送郵件函數
async function sendMail(text,receive) {
let user = "703669046@qq.com";//自己的郵箱
let pass = "sfsdfsdfsggxcew"; //qq郵箱授權碼
let to = `${receive}@qq.com`; //對方的郵箱
let transporter = nodemailer.createTransport({
host: "smtp.qq.com",
port: 587,
secure: false,
auth: {
user: user, // 用戶賬號
pass: pass, //授權碼,通過QQ獲取
},
});
let info = await transporter.sendMail({
from: `測試node發(fā)送郵箱<${user}>驗證碼`, // sender address
to: `測試驗證碼<${to}>`, // list of receivers
subject: "測試驗證碼", // Subject line
text: text, // plain text body
});
}編寫connect、body-parser解析模塊
var app = connect()
.use(bodyParser.json()) //JSON解析
.use(bodyParser.urlencoded({ extended: true }))
//use()方法還有一個可選的路徑字符串,對傳入請求的URL的開始匹配。
//use方法來維護一個中間件隊列跨域請求設置
.use(function (req, res, next) {
//跨域處理
// Website you wish to allow to connect
res.setHeader('Access-Control-Allow-Origin', '*'); //允許任何源
// Request methods you wish to allow
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE'); //允許任何方法
// Request headers you wish to allow
res.setHeader('Access-Control-Allow-Headers', '*'); //允許任何類型
res.writeHead(200, { "Content-Type": "text/plain;charset=utf-8" }); //utf-8轉碼
next(); //next 方法就是一個遞歸調用
})編寫發(fā)送qq郵箱驗證碼接口
.use('/emails', function (req, res, next) {
let qqEmail= req.body.email;
var obj = {
code:Math.ceil(Math.random()*1000)
};
let text=`驗證碼:${obj.code}.您正在使用登錄功能,驗證碼提供他人可能導致賬號被盜,請勿轉發(fā)或泄漏`
sendMail(text,qqEmail)
res.end(JSON.stringify(obj))
next();
})設置端口
在var app = connect()后面接上
.listen(3331);
啟動node服務
在index.js當前文件下開啟cmd命令提示符或者Git命令框執(zhí)行node index.js命令
前端模塊
我是使用vue-cli+elementui
- html代碼部分
<template>
<div>
<el-form
:model="ruleForm"
status-icon
ref="ruleForm"
label-width="100px"
class="demo-ruleForm"
>
<el-form-item label="QQ" prop="email">
<el-input type="email" v-model="ruleForm.email" autocomplete="off"></el-input>
<el-button @click="handleCode">獲取驗證碼</el-button>
</el-form-item>
<el-form-item label="驗證碼" prop="code">
<el-input v-model.number="ruleForm.code"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
<el-button @click="resetForm('ruleForm')">重置</el-button>
</el-form-item>
</el-form>
</div>
</template>效果圖

js請求代碼部分
import ajax from '../../utli/request'
export const getCheckCode = param => ajax.$post('/emails', param || {});js事件部分
<script>
import {getCheckCode} from './api/form'
export default {
data() {
return {
ruleForm: {
email: "",
checkPass: "",
code: ""
},
};
},
methods: {
submitForm(formName) {
this.$refs[formName].validate(valid => {
if (valid) {
alert("submit!");
} else {
console.log("error submit!!");
return false;
}
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
},
async handleCode(){
let params= {
email:this.ruleForm.email
}
let res = await getCheckCode(params);
if(res.state==200){
console.log(res)
}
}
}
};
</script>發(fā)送qq驗證給用戶

成功收到郵箱驗證碼

總結
到此這篇關于如何利用node實現發(fā)送QQ郵箱驗證碼的文章就介紹到這了,更多相關node發(fā)送QQ郵箱驗證碼內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
利用nodejs讀取圖片并將二進制數據轉換成base64格式
這篇文章主要介紹了利用nodejs讀取圖片并將二進制數據轉換成base64格式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08
Node.js 服務器端應用開發(fā)框架 -- Hapi.js
Hapi.js 是一個用來構建基于 Node.js 的應用和服務的富框架,使得開發(fā)者把重點放在便攜可重用的應用邏輯而不是構建架構。內建輸入驗證、緩存、認證和其他 Web 應用開發(fā)常用的功能。2014-07-07
NPM命令運行報錯:npm?v10.2.4?is?known?not?to?run?on?Node.js
這篇文章主要給大家介紹了關于NPM命令運行報錯:npm?v10.2.4?is?known?not?to?run?on?Node.js?v14.21.1的解決辦法,文中將解決辦法介紹的非常詳細,需要的朋友可以參考下2024-01-01

