携帯電話番号の歩数記録を取得するWeChatアプレット

携帯電話番号の歩数記録を取得するWeChatアプレット

序文

最近、小さなプログラムを開発しているときに、このような問題に遭遇しました。ユーザーが認証をクリックして携帯電話番号を復号化しようとすると、1 回目は失敗しますが、2 回目は成功します。しばらく勉強した後、ようやくもっと合理的な解決策を見つけました。皆さんのお役に立てればと思い、ここに記録してまとめておきます。

要件の説明

ユーザーが「電話を取得」ボタンをクリックすると、WeChatでユーザーが設定した電話番号が復号化され、連絡先の電話番号入力ボックスに表示されます。

特定のコード

      <view class="cu-form-group">
            <view class="title text-black">連絡先電話番号</view>
            <input class="radius" name="mobile" placeholder="連絡先の電話番号を入力してください" value="{{detail.mobile}}" bindinput="onInputMobile"></input>
            <button bindgetphonenumber="getPhoneNumber" class="cu-btn line-blue sm" openType="getPhoneNumber">電話番号を取得</button>
        </ビュー>

まず、アプレットボタンコンポーネントが必要で、openType="getPhoneNumber" を設定します。

    onLoad: 非同期関数() {
        this.getSessionKey()
    },
    非同期getSessionKey() {
        const { コード } = wx.login() を待つ
        const res = Index.getSessionKey({
            コード
        })
        (res.code == 1)の場合{
            this.setData({
                セッションキー: res.data
            })
        }
    },
    getPhoneNumber: 非同期関数(e) {
        if (e.detail.errMsg === "getPhoneNumber:ok") {
            const res = Index.getPhone({
                iv: e.詳細.iv、
                暗号化データ: e.detail.encryptedData、
                セッションキー: this.data.session_key
            })
            (res.err == 0)の場合{
                wx.showToast({
                    タイトル: 「ネットワークが少し不安定です。もう一度クリックしてお試しください」
                    アイコン: 'なし'
                })
                戻る
            }
            const 詳細 = this.data.detail
            detail.mobile = res.err.phoneNumber
            this.setData({
                詳細
            })
        } そうでない場合 (e.detail.errMsg === "getPhoneNumber:fail user deny") {
            wx.showModal({
                タイトル: 「ヒント」
                内容: 「認証を拒否しました。もう一度クリックして認証してください」
                表示キャンセル: false、
                confirmText: 「了解しました」
            })
        }
    },

onLoadライフサイクル中にログインコードを取得し、そのコードをサーバーに送信してsession_keyを取得します。

サーバー側で session_key を取得するには、ミニプログラムの公式ドキュメントを参照してください。

ユーザーが「Get Phone」ボタンをクリックすると、session_key と取得された iv、encryptedData が復号化のためにサーバーに送信されます。

この方法でユーザーの携帯電話番号を取得できます。

ピット

以前の解決策では、ユーザーが [電話番号を取得] ボタンをクリックした後、getPhoneNumber 関数で wx.logon() を直接呼び出し、コード、iv、encryptedData をサーバーに送信していました。サーバーは最初にコードを使用して session_key を取得し、次にそれを iv および encryptedData と組み合わせて復号化しました。この方法では、最初の復号化は失敗し、次にボタンをもう一度クリックして復号化インターフェイスを呼び出すと成功します。 そして、この状況は 5 ~ 6 分ごとに再発します。

ログイン状態が期限切れになっているかどうかを確認するために wx.checkSession(Object object) を呼び出すと、常に成功します。

推測

後で考えてみたのですが、getPhoneNumber 関数で wx.login を呼び出して、サーバーがコードを使用して session_key を交換し、それを iv と組み合わせて、encryptedData を復号化できないのはなぜでしょうか? session_key を取得するために、wx.login を onLoad に入れるのはどうでしょうか?

wx.login が呼び出されると、WeChat サーバーの session_key が更新されると思います。getPhoneNumber で wx.login が直接呼び出されると、WeChat サーバーはそれを更新する時間がない可能性があり、サーバーはそれを復号化に使用します。前回期限が切れた session_key は引き続き復号化に使用されるため、2 回目以降にのみ成功します。 onload に wx.login を配置すると、session_key を時間内に取得できます。

要約する

WeChatミニプログラムを通じて携帯電話番号を取得する際の落とし穴に関するこの記事はこれで終わりです。WeChatミニプログラムを通じて携帯電話番号を取得することに関するより関連性の高いコンテンツについては、123WORDPRESS.COMで以前の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後も123WORDPRESS.COMを応援していただければ幸いです。

以下もご興味があるかもしれません:
  • WeChatミニプログラムでユーザー認証を通じて携帯電話番号を取得する方法(getPhoneNumber)
  • WeChatアプレットは、ユーザーのログイン機能を承認するために携帯電話番号を取得します
  • WeChatミニプログラムのユーザー認証、位置情報認証、WeChatにバインドされた携帯電話番号の取得
  • WeChatアプレット機能の概要(携帯電話番号認証*、パスワード認証*、認証コードの取得*)
  • WeChatミニプログラムでユーザーの携帯電話番号を取得する方法
  • WeChatアプレットgetPhoneNumberはユーザーの携帯電話番号を取得します
  • WeChatアプレットはユーザー情報と携帯電話番号を取得します(バックエンドTP5.0)
  • WeChat アプレット開発: ユーザーの携帯電話番号の取得 (PHP インターフェースの復号化)
  • WeChatアプレットは携帯電話番号をバインドして認証コード機能を取得します
  • 携帯電話番号を取得するためのWeChatアプレットJavaScript復号化サンプルコードの詳細な説明

<<:  MySQL の char、varchar、text フィールド タイプの違い

>>:  MySQL の null 可能フィールドは NULL に設定する必要がありますか、それとも NOT NULL に設定する必要がありますか?

推薦する

Zabbix カスタム監視 nginx ステータス実装プロセス

目次Zabbix カスタム監視 nginx ステータス1. ステータスインターフェースを開く2. 監...

タイムスタンプの差を計算するSQLメソッド

タイムスタンプの差を計算するSQLメソッド概要場合によっては、特定のレコードを時間で検索する必要があ...

Dockerコンテナを更新、パッケージ化、Alibaba Cloudにアップロードする方法

今回は、実行中のコンテナをイメージにパッケージ化して Alibaba Cloud にアップロードし、...

Webデザインチュートリアル(6):デザインへの情熱を持ち続ける

<br />前の記事:Webデザインチュートリアル(5):Webビジュアルデザイン。 1...

JavaScript は大容量ファイルのアップロード処理を実装します

数十 MB 程度の小さいものから 1G 以上の大きいものまで、ビデオ ファイルなどのファイルのアップ...

Ubuntu16.04にclionをインストールするプロセス全体と手順の詳細な説明

CLion のプロセス全体を最初から説明します。CLion は、JetBrains がリリースした新...

Nginxはhttpリクエスト実装プロセス分析を処理する

Nginxはまず、設定ファイル内のどのserver{}ブロックを処理に使用するかを決定します。次のs...

HTML テーブルの空白セル補完を実装する方法

私が初めて Web 開発を独学で学んだ頃は、いわゆる DIV/CSS レイアウトはなく、テーブル レ...

JavaScript は最大値と最小値のアルゴリズムを通じて AI 三目並べゲームを実装します

では、早速スクリーンショットを実行してみましょう。黒い駒はプレイヤーの位置、赤い駒はコンピュータの位...

CocosCreator クラシック エントリー プロジェクト flappybird

目次開発環境ゲームエンジンのコンセプトCocos Creatorについてプロジェクト構造コード編集環...

CentOS 7のインストールと設定方法のグラフィックチュートリアル

この記事は、CentOS 7の詳細なインストールチュートリアルを参考のために記録します。具体的な内容...

Linux で特定のユーザーにフォルダーのすべてのコンテンツを許可するにはどうすればよいですか?

【問題分析】 chown コマンドを使用できます。ここで ch は change (変更) を表し...

Vue echarts は水平棒グラフを実現します

この記事では、水平棒グラフを実現するためのvue echartsの具体的なコードを参考までに共有しま...

nodejsとyarnをインストールし、Taobaoソースプロセスレコードを構成する

目次1. nodejsをダウンロードする2. ダブルクリックしてインストール3. グローバル npm...

sqlmap インジェクションの詳細なグラフィック説明

目次1. この Web サイトには SQL インジェクションの脆弱性がある可能性があることが判明しま...