Node の SMS API で検証コード ログインを実装するためのサンプル コード

Node の SMS API で検証コード ログインを実装するためのサンプル コード

1. ノードサーバーのセットアップ + データベース接続

ここでの操作は比較的簡単でわかりやすいです。ノードサーバーのクイックセットアップを参照してください。

2. SMS APIの使用

SMS APIについては、ここではAlibaba CloudのSMSサービスを例に挙げます(SMSサービスを備えたプラットフォームであればどれでも使用できます)。

2.1 プラットフォームにログインしてパラメータを設定する

1. SMS コンソールに入り、送信する SMS の形式を設定します。署名がない場合は、操作前に署名を申請する必要があります。

ここに画像の説明を挿入

2. APIデモの表示をクリックして、設定されたAPIに入り、Node.jsを選択します。

ここに画像の説明を挿入

2.2 生成されたAPIをプロジェクトで使用する

コードコメントは詳細です

const Core = require('@alicloud/pop-core'); //cwen は Ali SMS モジュールを呼び出します (最初にインストールする必要があります)
//cwenはAlibaba SMSサービスAPIを設定します。let client = new Core({
 accessKeyId: '<accessKeyId>', // 最初に適用する必要があります (以下の手順を参照)
 accessKeySecret: '<accessSecret>', // 最初に適用する必要があります (以下の手順)
 エンドポイント: 'https://dysmsapi.aliyuncs.com', // 変更する必要はありません apiVersion: '2017-05-25' // 変更する必要はありません });
//cwenリクエストメソッドlet requestOption = {
  メソッド: 'POST'
};

//# 検証コードをシミュレートするためにランダムな4桁の数字を生成する function rander(max, min) {
  Math.floor(Math.random() * (max - min)) + min を返します。
}
//# 携帯電話番号 + 確認コードを保存します(簡単に確認するため)
var ログイン情報 = [];
//# 電話番号が確認コードを送信したかどうかを確認する let validate = (phone) => {
  loginInfo.some(item => item.phone === phone) を返します
}
//# 検証コードが一致していることを確認する let validateCode = (phone, code) => {
  loginInfo.some(item => (item.phone === 電話 && item.code == コード)) を返します
}

//cwen は Alibaba Cloud API を使用して SMS 認証 (認証コード ログイン) を送信します
sendLoginCroeCode = async(req, res) => { を設定します。
  { 電話番号 } を req.body とします。
  randCode = rander(1000, 9999);とします。
  var パラメータ = {
      "RegionId": "cn-杭州",
      "PhoneNumbers": phone, // クライアントの電話番号 "SignName": "小陈于用ya", // 署名 "TemplateCode": "SMS_197625305", // テンプレート、テキスト メッセージを送信するために使用 "TemplateParam": JSON.stringify({ 'code': randCode }) // 送信する検証コードを指定します (ここでは rander 関数が例として使用されています)
    }
     //# 確認コードを送信する前に、携帯電話番号が登録されているかどうかを確認します。if (await isRegister(phone)) { // これはデータベース操作です(無視できます)
    client.request('SendSms', params, requestOption).then((result) => {
      結果コード == 'OK' の場合 {
        res.send({
          ステータス: 200、
          メッセージ: '送信に成功しました'
        });
        loginInfo.push({
          電話: 電話、
          コード: randCode
        });
        console.log(ランダムコード)
      } それ以外 {
        res.send({
          ステータス: 400、
          メッセージ: '送信に失敗しました'
        })
      }
    })
  } それ以外 {
    res.send({
      ステータス: 400、
      メッセージ: 「この電話番号は登録されていません」
    })
  }
}

//# 検証コードログインインターフェース let phoneCodeLogin = async(req, res) => {
  let { 電話番号、コード } = req.body;
  if (validate(phone)) { //携帯電話番号が認証コードを送信したかどうかを判断しますif (validateCode(phone, code)) { //認証コードが携帯電話番号と一致するかどうかを判断しますlet user = await isFirstLogin(phone); //これはユーザー情報を取得するためのデータベース操作です(無視できます)
      res.send({
        ステータス: 200、
        メッセージ: 'ログイン成功'、
        データ: ユーザー[0]
      })
      loginInfo = []; // ログインが成功したら、検証コードの再送信に失敗しないようにすぐに配列をクリアします} else {
      res.send({
        ステータス: 400、
        メッセージ: '認証コードエラー'
      })
    }
  } それ以外 {
    res.send({
      ステータス: 400、
      メッセージ: 「認証コードを取得できませんでした」
    })
  }
}

// 注意: 最後にインターフェースを公開することを忘れないでください

注意: accessKeyId、accessKeySecret使用前に申請する必要があります

ここに画像の説明を挿入

3. インターフェースを使用してログインする

ここではPostmanインターフェースデバッグツールを例にとり、携帯電話番号はデータベースに登録されている携帯電話番号です。

確認コードをリクエストする

ここに画像の説明を挿入

携帯電話で認証コードを受け取る

ここに画像の説明を挿入

認証コードログイン

ここに画像の説明を挿入

Node で SMS API を使用して認証コード ログインを実装するためのサンプル コードに関するこの記事はこれで終わりです。Node SMS 認証コード ログインに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Ali は SMS 検証コードより大きいノード koa2 実装コード (最新)
  • nodejs で Ali Dayu SMS 認証コードにアクセスする方法
  • Nodejs は Post リクエスト関数を送信します (SMS 検証コードの例を送信)
  • Nodejs が SMS 認証コード機能を実装

<<:  MySQL がテーブルを読み取れないエラー (MySQL 1018 エラー) の解決方法

>>:  Linuxのファイル権限の詳細な紹介

推薦する

ネイティブ js を使用してライブ バレット スクリーンのスクロール効果をシミュレートします。

目次1. 基本原則2. 特定のコード要約する1. 基本原則まず、生放送エリアを10の部分に分割し(個...

JavaScript 配列メソッドの詳細な例

目次導入配列の作成作成方法詳しい説明方法参加する() push() と pop() shift() ...

WeChat アプレットのカスタム タブバー コンポーネント

この記事では、WeChatアプレットのカスタムタブバーコンポーネントの具体的なコードを参考までに紹介...

Vue双方向バインディングの詳細な説明

目次1. 双方向バインディング2. 他のタグを選択した場合にも同じ結果になりますか? 答えはもちろん...

Nodejs プラグインと使用方法の概要

このチュートリアルの動作環境: Windows 7 システム、nodejs バージョン 12.19....

さまざまなネットワーク画像形式におけるPNGの利点の詳細な説明

BMP は、ハードウェア デバイスに依存せず、広く使用されている画像ファイル形式です。ビットマップ保...

HTML と CSS を使用して絵文字付きのコメント ボックスを作成する方法のチュートリアル

絵文字付きの HTML コメント ボックス。絵文字は Json データを通じて読み込まれ、好みに応じ...

HTML(CSSスタイル仕様)を読む必要があります

CSS スタイル仕様1. クラスセレクター2. タグセレクター3. IDセレクター4. CSSスタイ...

React Nativeでaxiosを使用してネットワークリクエストを行う方法

フロントエンド開発では、Ajax、jQuery ajax、axios、fetch など、データ要求を...

Nginx は高可用性クラスタ構築を実装します (Keepalived+Haproxy+Nginx)

1. コンポーネントと実装機能Keepalived: Haproxy サービスの高可用性を実現し、...

MySQLの一般クエリログとスロークエリログの分析

MySQL のログには、エラー ログ、バイナリ ログ、一般クエリ ログ、スロー クエリ ログなどが含...

Linux環境でIPV6接続をサポートするようにmysql5.6を設定する方法

導入:この記事では主に、Linux システムで IPV6 接続をサポートするように MySQL を構...

HTML 形式の JSON 出力の例 (テスト インターフェース)

JSON データを美しいインデント形式で表示するには、最も単純な JSON.stringify 関...

JavaScript でプロパティハイジャックを実装する方法 defineProperty

目次序文記述子getとsetの詳細な説明オブジェクトの属性の乗っ取りオブジェクトのすべてのプロパティ...

MySQL レプリケーション問題の 3 つのパラメータの分析

目次01 sql_slave_skip_counter パラメータ02 スレーブスキップエラーパラメ...