小程序获取手机号及手机号解密


1.获取手机号

获取手机号的过程官方文档有详细的介绍。参考官方链接
要注意的是,此功能只对非个人且完成认证的开发者开发,个人开发者无法使用该功能。获取微信用户绑定的手机号,需先调用wx.login接口。

<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button>
//js文件调用获取事件
Page({
  getPhoneNumber (e) {
    this.data = e;
    console.log("1 errMsg", e.detail.errMsg)
    console.log("2 iv", e.detail.iv)
    console.log("3 encryptedData", e.detail.encryptedData)

    var that = this;
    var sessionkey = "";
    var openid = "";
  }
})

这里主要使用到的数据为e.detail.iv和e.detail.encryptedData。此时返回的数据为加密过的手机号码数据,若想显示或者进行验证则需进行数据解密。

2.解密(全局js文件中添加)

手机号码解密主要使用到的数据为:appId(开发者appid)、 session_key、 encryptedData(上边方法中获取的e.detail.encryptedData)、iv(上边方法中获取的e.detail.iv)。
所以在所需数据方面主要要获取的就是session_key。参考官方链接
获取session_key所需的主要参数为:appid、secret(这两个参数都可以在小程序官方-开发-开发设置中获取)、js_code

  globalData: {
    codeitem: '', // code
    phone: '', //解密后的手机号
  },
  
  let that = this;
    wx.login({
      success(res) {
        that.globalData.codeitem = res.code;
        console.log("0 登录后返回值", that.globalData.codeitem);
      }
    })

3.获取session_key

    var that = this;
    var sessionkey = "";
    var openid = "";
    setTimeout(() => {
      wx.request({

        url: 'https://api.weixin.qq.com/sns/jscode2session?appid=' + config.appId + '&secret=' + config.sessionKey + '&js_code=' + app.globalData.codeitem + '&grant_type=authorization_code',
        method: 'POST',
        header: {
          'content-type': 'application/json'
        },
        success: function (res) {
          console.log("4", res);
          // that.setData({
          sessionkey = res.data.session_key,
            openid = res.data.openid
          // })
        }
      })
    }, 500)


4.解密返回数据

手机号码解密主要使用的是 CryptoJS 包,点击下载
cryptojs-master下载地址

WXBizDataCrypt.js文件:

/**
 * Created by rd on 2017/5/4.
 */
// 引入CryptoJS  路径依个人导入情况变动
var Crypto = require('../cryptojs-master/cryptojs.js').Crypto;
var app = getApp();

function RdWXBizDataCrypt(appId, sessionKey) {
  this.appId = appId
  this.sessionKey = sessionKey
}

RdWXBizDataCrypt.prototype.decryptData = function (encryptedData, iv) {
  // base64 decode :使用 CryptoJS 中 Crypto.util.base64ToBytes()进行 base64解码
  var encryptedData = Crypto.util.base64ToBytes(encryptedData)
  var key = Crypto.util.base64ToBytes(this.sessionKey);
  var iv = Crypto.util.base64ToBytes(iv);

  // 对称解密使用的算法为 AES-128-CBC,数据采用PKCS#7填充
  var mode = new Crypto.mode.CBC(Crypto.pad.pkcs7);
  
  try {
    // 解密
    var bytes = Crypto.AES.decrypt(encryptedData, key, {
        asBpytes:true,
        iv: iv,
        mode: mode
    });
    
    var decryptResult = JSON.parse(bytes);
    
  } catch (err) {
    console.log(err)
  }


  return decryptResult
}

module.exports = RdWXBizDataCrypt

5.页面wxml中添加按钮

   setTimeout(() => {
      var WXBizDataCrypt = require('./utils/WXBizDataCrypt')


      //需解密的事件中添加下边代码获取解密后的手机号码
      var appId = config.appId
      var sessionKey = sessionkey
      var encryptedData = e.detail.encryptedData
      var iv = e.detail.iv

      var pc = new WXBizDataCrypt(appId, sessionKey)
      var data = pc.decryptData(encryptedData, iv)
      if (data == undefined || data == null || data == '') {
        // this.getPhoneNumber(this.data);
      }
      console.log('5 解密后 data: ', data)
      that.phone = data.phoneNumber;
      app.globalData.phone = data.phoneNumber
      console.log("that.app.globalData.phone", app.globalData.phone)
      that.onShow()
    }, 1000)

最终效果

在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
解密微信小程序获取手机号的过程需要以下步骤: 1. 首先,在wxml文件中,使用`button`按钮设置`open-type="getPhoneNumber"`并绑定`bindgetphonenumber`事件\[1\]\[2\]。 ```html <button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button> ``` 2. 在js文件中,定义`getPhoneNumber`函数,并在函数中获取手机号的加密数据\[1\]。 ```javascript Page({ getPhoneNumber(e) { console.log(e.detail.errMsg); console.log(e.detail.iv); console.log(e.detail.encryptedData); } }) ``` 3. 在第三方服务端,结合小程序的`session_key`和`app_id`,使用相应算法对加密数据进行解密,从中获取手机号\[2\]\[4\]。解密使用到的数据主要包括`appId`(开发者appid)、`session_key`、`encryptedData`(从`e.detail.encryptedData`获取)和`iv`(从`e.detail.iv`获取)。其中,为了获取`session_key`,需要使用`js_code`参数调用`wx.login`接口\[3\]。 总结起来,解密微信小程序获取手机号的过程包括用户点击获取手机号按钮,获取到加密数据后,在第三方服务端结合`session_key`和`app_id`进行解密操作,最终获取到真实手机号码\[1\]\[2\]\[3\]\[4\]。 #### 引用[.reference_title] - *1* [微信小程序获取手机号解密详解](https://blog.csdn.net/a_115098/article/details/108491494)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-7e93130b2a59999b59aa9656ab5ec596.142^v90^chatsearch,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [微信小程序实现获得用户手机号](https://blog.csdn.net/weixin_30951743/article/details/95030461)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-7e93130b2a59999b59aa9656ab5ec596.142^v90^chatsearch,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [微信小程序获取手机号解密详解](https://blog.csdn.net/a_115098/article/details/108491494)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-7e93130b2a59999b59aa9656ab5ec596.142^v90^chatsearch,239^v3^insert_chatgpt"}} ] [.reference_item] - *4* [微信小程序获取手机号解密详解](https://blog.csdn.net/a_115098/article/details/108491494)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-7e93130b2a59999b59aa9656ab5ec596.142^v90^chatsearch,239^v3^insert_chatgpt"}} ] [.reference_item] - *5* [微信小程序前端解密获取手机号](https://blog.csdn.net/qq_35946021/article/details/127995447)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-7e93130b2a59999b59aa9656ab5ec596.142^v90^chatsearch,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汪杰杰杰杰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值