1.获取手机号
//wxml文件使用button按钮触发获取手机号事件,open-type="getPhoneNumber" 不能少
//js文件调用获取事件
Page({
getPhoneNumber (e) {
console.log(e.detail.errMsg)
console.log(e.detail.iv)
console.log(e.detail.encryptedData)
}
})
2.解密
2.1 获取所需数据
手机号码解密主要使用到的数据为:appId(开发者appid)、 session_key、 encryptedData(上边方法中获取的e.detail.encryptedData)、iv(上边方法中获取的e.detail.iv)。
所以在所需数据方面主要要获取的就是session_key。参考官方链接
获取session_key所需的主要参数为:appid、secret(这两个参数都可以在小程序官方-开发-开发设置中获取)、js_code。
//获取js_code
wx.login({
success (res) {
console.log(res.code);
}
})
最终获取session_key。
wx.request({
url: 'https://api.weixin.qq.com/sns/jscode2session?appid=' + 开发者appid + '&secret=' + 开发者secret + '&js_code=' + 获取的code + '&grant_type=authorization_code',
method: 'POST',
header: {
'content-type': 'application/json'
},
success: function (res) {
console.log(res.data.session_key);
}
})
2.2 解密返回数据
手机号码解密:var Crypto = require('cryptojs/cryptojs.js').Crypto;主要使用的是 下包文件cryptojs-master里面的cryptojs.js文件,点击下载。 新建文件夹utils将下载的文件放在里面
微信官方提供了多种编程语言的示例代码,(点击下载)但是没有js包,这里根据参考进行了稍微修改。
WXBizDataCrypt.js文件:
// 引入CryptoJS
var Crypto = require('../utils/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)
}
if (decryptResult.watermark.appid !== this.appId) {
console.log(err)
}
return decryptResult
}
module.exports = RdWXBizDataCrypt
在需要解密的页面进行引入WXBizDataCrypt.js。
var WXBizDataCrypt = require('../../utils/WXBizDataCrypt')
//需解密的事件中添加下边代码获取解密后的手机号码
var appId = 开发者appid
var sessionKey = 获取的sessionkey
var encryptedData = encryptedData
var iv = iv
var pc = new WXBizDataCrypt(appId, sessionKey)
var data = pc.decryptData(encryptedData , iv)
console.log('解密后 data: ', data)
参考文档