微信小程序用戶信息encryptedData詳解
之前做過一個(gè)版本是根據(jù)encryptData和Session_key解密得到完整的用戶信息(包含union_id)的方法去獲取用戶信息,由于小程序升級(jí),如今需要廢棄encryptData的方式去獲取用戶信息,改成使用encryptedData的方式獲取用戶信息。
新的數(shù)據(jù)解密方法
接口如果涉及敏感數(shù)據(jù)(如wx.getUserInfo當(dāng)中的 openId 和unionId ),接口的明文內(nèi)容將不包含這些敏感數(shù)據(jù)。開發(fā)者如需要獲取敏感數(shù)據(jù),需要對(duì)接口返回的加密數(shù)據(jù)( encryptedData )進(jìn)行對(duì)稱解密。 解密算法如下:
對(duì)稱解密使用的算法為 AES-128-CBC,數(shù)據(jù)采用PKCS#7填充。
對(duì)稱解密的目標(biāo)密文為 Base64_Decode(encryptedData),
對(duì)稱解密秘鑰 aeskey = Base64_Decode(session_key), aeskey 是16字節(jié)
對(duì)稱解密算法初始向量 iv 會(huì)在數(shù)據(jù)接口中返回。
微信官方提供了多種編程語言的示例代碼。每種語言類型的接口名字均一致。調(diào)用方式可以參照示例。
另外,為了應(yīng)用能校驗(yàn)數(shù)據(jù)的有效性,我們會(huì)在敏感數(shù)據(jù)加上數(shù)據(jù)水印( watermark )
{ "openId": "OPENID", "nickName": "NICKNAME", "gender": GENDER, "city": "CITY", "province": "PROVINCE", "country": "COUNTRY", "avatarUrl": "AVATARURL", "unionId": "UNIONID", "watermark": { "appid":"APPID", "timestamp":TIMESTAMP } }
總的來說還是原來的算法,還是原來的邏輯結(jié)構(gòu),不同的是解密方式,以前是通過session_key得到iv,現(xiàn)如今是直接從前臺(tái)接口處得到iv來解密,所改變的也只是傳輸?shù)臄?shù)據(jù)
@RequestMapping(value = "/web/wechatapp/jscode2session", method = RequestMethod.POST) @ResponseBody public String getSessionByCode(@RequestBody String jsonStr, HttpServletRequest request) { JSONObject jsonObj = JSONObject.fromObject(jsonStr); String code = (String) jsonObj.get("code"); JSONObject wechatAppUserInfo = jsonObj.getJSONObject("wechatAppUserInfo"); String encryptedData = (String) wechatAppUserInfo.get("encryptedData"); String iv = (String) wechatAppUserInfo.get("iv"); WechatUserInfo wechatUserInfo = wechatAppManager.doOAuth(code, encryptedData, iv); if (wechatUserInfo == null) { throw new BusinessException(BusinessException.Code.WECHAT_OAUTH_ERROR, "微信小程序授權(quán)失?。。?!"); } HttpSession session = request.getSession(true); User user = wechatUserInfo.getUser(); logger.debug("微信小程序用戶 union id: {}, 對(duì)應(yīng)車車用戶{}", wechatUserInfo.getUnionid(), user.getId()); session.setAttribute(WebConstants.SESSION_KEY_USER, CacheUtil.doJacksonSerialize(user)); ClientTypeUtil.cacheClientType(request, ClientType.WE_CHAT_APP); return session.getId(); }
解密的算法
public static byte[] decrypt(String dataStr,String keyStr, String ivStr) throws Exception{ Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider()); byte[] encryptedData = Base64.decode(dataStr); byte[] keyBytes = Base64.decode(keyStr); AlgorithmParameters iv = WechatAppDecryptor.generateIV(Base64.decode(ivStr)); Key key = convertToKey(keyBytes); Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); //設(shè)置為解密模式 cipher.init(Cipher.DECRYPT_MODE, key,iv); return cipher.doFinal(encryptedData); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于document.cookie的使用javascript
設(shè)置cookie 每個(gè)cookie都是一個(gè)名/值對(duì),可以把下面這樣一個(gè)字符串賦值給document.cookie:2008-04-04IE6/IE7中JavaScript json提示缺少標(biāo)識(shí)符、字符串或數(shù)字問題處理
這篇文章主要介紹了IE6/IE7中JavaScript json提示缺少標(biāo)識(shí)符、字符串或數(shù)字問題處理,需要的朋友可以參考下2014-12-12瀏覽器視頻幀操作方法?requestVideoFrameCallback()
這篇文章主要介紹了瀏覽器視頻幀操作方法?requestVideoFrameCallback(),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07js獲取GridView中行數(shù)據(jù)的兩種方法 分享
這篇文章介紹了js獲取GridView中行數(shù)據(jù)的方法,有需要的朋友可以參考一下2013-07-07封裝了一個(gè)支持匿名函數(shù)的Javascript事件監(jiān)聽器
這篇文章主要介紹了支持匿名函數(shù)的Javascript事件監(jiān)聽封裝,需要的朋友可以參考下2014-06-06小程序數(shù)據(jù)緩存機(jī)制應(yīng)用實(shí)現(xiàn)
這篇文章主要介紹了小程序數(shù)據(jù)緩存機(jī)制應(yīng)用實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05js實(shí)現(xiàn)仿阿里巴巴城市選擇框效果實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)仿阿里巴巴城市選擇框效果,實(shí)例分析了javascript結(jié)合css與數(shù)組實(shí)現(xiàn)城市選擇框的方法,需要的朋友可以參考下2015-06-06JS實(shí)現(xiàn)瀏覽器狀態(tài)欄文字閃爍效果的方法
這篇文章主要介紹了JS實(shí)現(xiàn)瀏覽器狀態(tài)欄文字閃爍效果的方法,通過時(shí)間函數(shù)定時(shí)觸發(fā)遞歸調(diào)用實(shí)現(xiàn)狀態(tài)欄文字閃爍效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10基于JS組件實(shí)現(xiàn)拖動(dòng)滑塊驗(yàn)證功能(代碼分享)
拖動(dòng)滑塊驗(yàn)證功能在支付寶,微信各大平臺(tái)都能見到這樣的功能,那么基于js組件是如何實(shí)現(xiàn)此功能的呢?今天小編就給大家分享下js 拖動(dòng)滑塊 驗(yàn)證功能的實(shí)現(xiàn)代碼,需要的朋友參考下吧2016-11-11