小程序获取手机号并解密
<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button>
//js文件调用获取事件
Page({
getPhoneNumber (e) {
console.log(e.detail.errMsg)
console.log(e.detail.iv)
console.log(e.detail.encryptedData)
}
})
这里主要使用到的数据为e.detail.iv和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。
2.2 解密返回数据
/**
* 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
在需要解密的页面进行引入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)
