微信小程序encryptedData敏感信息接码
生活随笔
收集整理的這篇文章主要介紹了
微信小程序encryptedData敏感信息接码
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
public static JSONObject getUserInfo(String encryptedData, String sessionKey, String iv){// 被加密的數據byte[] dataByte = Base64.decode(encryptedData);// 加密秘鑰byte[] keyByte = Base64.decode(sessionKey);// 偏移量byte[] ivByte = Base64.decode(iv);try {// 如果密鑰不足16位,那么就補足. 這個if 中的內容很重要int base = 16;if (keyByte.length % base != 0) {int groups = keyByte.length / base + (keyByte.length % base != 0 ? 1 : 0);byte[] temp = new byte[groups * base];Arrays.fill(temp, (byte) 0);System.arraycopy(keyByte, 0, temp, 0, keyByte.length);keyByte = temp;}// 初始化Security.addProvider(new BouncyCastleProvider());Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding","BC");SecretKeySpec spec = new SecretKeySpec(keyByte, "AES");AlgorithmParameters parameters = AlgorithmParameters.getInstance("AES");parameters.init(new IvParameterSpec(ivByte));cipher.init(Cipher.DECRYPT_MODE, spec, parameters);// 初始化byte[] resultByte = cipher.doFinal(dataByte);if (null != resultByte && resultByte.length > 0) {String result = new String(resultByte, "UTF-8");return JSONObject.parseObject(result);}} catch (Exception e) {e.printStackTrace();}return null;}
其中
encryptedData為wx.getUserProfile返回包括敏感數據在內的完整用戶信息的加密數據,
iv為wx.getUserProfile返回加密算法的初始向量
sessionKey為會話密鑰,可通過以下接口獲取 GET https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_codejs_code為wx.login登錄時獲取的 code
總結
以上是生活随笔為你收集整理的微信小程序encryptedData敏感信息接码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 手机电脑如何使用OTG连接U盘教程及OT
- 下一篇: 无人机设计中的下一个进化步骤