溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

node.js如何實現(xiàn)手機號驗證碼登錄功能

發(fā)布時間:2022-08-12 10:46:45 來源:億速云 閱讀:254 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“node.js如何實現(xiàn)手機號驗證碼登錄功能”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

1.注冊容聯(lián)云通信賬號(免費)

node.js如何實現(xiàn)手機號驗證碼登錄功能

第二步 拿到自己的ACCOUNT_SIDAUTH_TOKEN、Rest_URL、AppID

node.js如何實現(xiàn)手機號驗證碼登錄功能

第三步注冊自己的測試手機號

node.js如何實現(xiàn)手機號驗證碼登錄功能

第四步 下載包

1.npm i md5 --save
2.npm i moment --save
3.npm i js-base64 --save
4.npm i request --save

一次下載 :npm i md5 moment js-base64 request --save 注意:package.json 看一下一定要全部安裝到位

第五步 寫代碼 創(chuàng)建文件夾 文件命名 自己隨意

可復(fù)制:    

const md5 = require('blueimp-md5')
const moment = require('moment')
const Base64 = require('js-base64').Base64;
const request = require('request');

/*
 生成指定長度的隨機數(shù)
 */
function randomCode(length) {
    const chars = ['0','1','2','3','4','5','6','7','8','9'];
    const result = ""; //統(tǒng)一改名: alt + shift + R
    for(var i = 0; i < length ; i ++) {
        var index = Math.ceil(Math.random()*9);
        result += chars[index];
    }
    return result;
}
// console.log(randomCode(6));
exports.randomCode = randomCode;

/*
向指定號碼發(fā)送指定驗證碼
 */
function sendCode(phone, code, callback) {
    const ACCOUNT_SID = '賬號上的 ACCOUNT_SID';
    const AUTH_TOKEN = '賬號上AUTH_TOKEN ';
    const Rest_URL = 'https://app.cloopen.com:8883';
    const AppID = '賬號上的AppID ';
    //1. 準備請求url
    /*
     1.使用MD5加密(賬戶Id + 賬戶授權(quán)令牌 + 時間戳)。其中賬戶Id和賬戶授權(quán)令牌根據(jù)url的驗證級別對應(yīng)主賬戶。
     時間戳是當(dāng)前系統(tǒng)時間,格式"yyyyMMddHHmmss"。時間戳有效時間為24小時,如:20140416142030
     2.SigParameter參數(shù)需要大寫,如不能寫成sig=abcdefg而應(yīng)該寫成sig=ABCDEFG
     */
    const sigParameter = '';
    const time = moment().format('YYYYMMDDHHmmss');
    sigParameter = md5(ACCOUNT_SID+AUTH_TOKEN+time);
    const url = Rest_URL+'/2013-12-26/Accounts/'+ACCOUNT_SID+'/SMS/TemplateSMS?sig='+sigParameter;

    //2. 準備請求體
    const body = {
        to : phone,
        appId : AppID,
        templateId : '1',
        "datas":[code,"1"]
    }
    //body = JSON.stringify(body);

    //3. 準備請求頭
    /*
     1.使用Base64編碼(賬戶Id + 冒號 + 時間戳)其中賬戶Id根據(jù)url的驗證級別對應(yīng)主賬戶
     2.冒號為英文冒號
     3.時間戳是當(dāng)前系統(tǒng)時間,格式"yyyyMMddHHmmss",需與SigParameter中時間戳相同。
     */
    const authorization = ACCOUNT_SID + ':' + time;
    authorization = Base64.encode(authorization);
    const headers = {
        'Accept' :'application/json',
        'Content-Type' :'application/json;charset=utf-8',
        'Content-Length': JSON.stringify(body).length+'',
        'Authorization' : authorization
    }

    //4. 發(fā)送請求, 并得到返回的結(jié)果, 調(diào)用callback
      // callback(true);
    request({
        method : 'POST',
        url : url,
        headers : headers,
        body : body,
        json : true
    }, function (error, response, body) {
        callback(body.statusCode==='000000');
    });
}
exports.sendCode = sendCode;

第六步 在接口文件夾引入

const {randomCode,sendCode}=require("../utils/getMessage");
// 登錄  注意:這個接口根據(jù)你自己的寫接口習(xí)慣更改  我這個接口用的是模塊化 對外暴露 在外界文件夾中引入使用
exports.login = (req,res)=>{
  let code=randomCode(6);//生成6位數(shù)字隨機驗證碼
  console.log(code)
  sendCode("15224745090",code,function(success){
      if(success){
          res.send("短信驗證碼已發(fā)送");
      }else{
          res.send("短信驗證碼發(fā)送失敗");
      }
  })

}

“node.js如何實現(xiàn)手機號驗證碼登錄功能”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI