微信小程序获取手机号步骤
1、前端调用 wx.login() 获取loginCode
wx.login({ success:function(res){ console.log('loginCode:', res.code) } });
2、后端拿到该 loginCode 发送https请求微信接口获取 session_key ,
该url也即获取 openidurl url为
https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code
返回结果
{ "session_key": "kI+3ookOAYC9olOcGzYPmQ", "openid": "oNZE65Pu0XfTg2yFP-dFks" }
3、前端调用 etPhoneNumber组件,用户确认授权。拿到encryptedData和iv。并传给后端。(此步骤不能在 1、2步骤之前)
<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"> </button>
getPhoneNumber: function(e) { console.log(e.detail.errMsg) console.log(e.detail.iv) console.log(e.detail.encryptedData) }
返回参数说明
参数 | 类型 | 说明 |
---|---|---|
encryptedData | String | 包括敏感数据在内的完整用户信息的加密数据,详细见加密数据解密算法 |
iv | String | 加密算法的初始向量,详细见加密数据解密算法 |
4、后端 用 session_key ,encryptedData ,iv 解密获取手机号
后端解密其实就这么简单,只要流程对了就可以解密,如果解密出错,基本就是流程出错了。不用再去换什么解密算法。
import com.anmoyi.common.Base64; //此包为自己封装的,只要能解密base64都行 import java.security.spec.AlgorithmParameterSpec; import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; /** * 解密用户手机号 * @param keyStr sessionkey * @param ivStr ivData * @param encDataStr 带解密数据 * @return * @throws Exception * @date 2019年05月08日 */ public static String decrypt(String keyStr, String ivStr, String encDataStr)throws Exception { byte[] encData = Base64.decode(encDataStr); byte[] iv =Base64.decode(ivStr); byte[] key = Base64.decode(keyStr); AlgorithmParameterSpec ivSpec = new IvParameterSpec(iv); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); SecretKeySpec keySpec = new SecretKeySpec(key, "AES"); cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec); return new String(cipher.doFinal(encData),"UTF-8"); }
返回
{ "phoneNumber": "187*********", "purePhoneNumber": "187********", "countryCode": "86", "watermark": { "appid":"APPID", "timestamp":TIMESTAMP } }