国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

微信小程序獲取用戶信息并保存登錄狀態詳解

2019-11-19 11:36:34
字體:
來源:轉載
供稿:網友

前言

微信小程序的運行環境不是在瀏覽器下運行的。所以不能以cookie來維護登錄態。下面我就來說說我根據官方給出的方法來寫出的維護登錄態的方法吧。

一、登錄態維護

官方的文檔地址:https://mp.weixin.qq.com/debug/wxadoc/dev/api/api-login.html#wxloginobject

通過 wx.login() 獲取到用戶登錄態之后,需要維護登錄態。開發者要注意不應該直接把 session_key、openid 等字段作為用戶的標識或者 session 的標識,而應該自己派發一個 session 登錄態(請參考登錄時序圖)。對于開發者自己生成的 session,應該保證其安全性且不應該設置較長的過期時間。session 派發到小程序客戶端之后,可將其存儲在 storage ,用于后續通信使用。

登錄時序圖

從上圖可以看出。當我們通過wx.login()獲取code的后,發送給我們的服務器,然后去請求微信服務器換取得到對應的openid與session_key,openid是該用戶在小程序中的唯一標識用于模板通知之類的。session_key就是用來解密用戶的敏感信息。unionid之類的。unionid是微信用戶在所有微信平臺下的唯一標識。下面我會講解一下如何得到。

以上就是我的實現方法。調用wx.login()得到code后請求服務器獲取openid與session_key緩存在服務器當中。其中生成一個隨機數為key,value為openid與session_key。然后返回到小程序通過wx.setStorageSync('LoginSessionKey',得到的隨機數key)緩存在小程序當中。每當我們去請求服務器時帶上LoginSessionKey即可給服務器讀取從而判斷用戶是否在登錄。是不是很簡單呢?

二、用戶數據的加解密

通過wx.login()登錄之后。我們可以通過wx.getUserInfo()獲取用戶信息。其中一些不敏感的信息在返回的 result中的userInfo里。如想要獲取敏感信息。openid,unionid之類的。則需要從密文中去解密得到。

而密文則在encryptedData這個字段當中。我們去請求我們服務器去解密然后得到敏感信息后則可以保存起來。

加密數據解密算法

接口如果涉及敏感數據(如wx.getUserInfo當中的 openId 和unionId ),接口的明文內容將不包含這些敏感數據。開發者如需要獲取敏感數據,需要對接口返回的加密數據( encryptedData )進行對稱解密。 解密算法如下:

  1. 對稱解密使用的算法為 AES-128-CBC,數據采用PKCS#7填充。
  2. 對稱解密的目標密文為 Base64_Decode(encryptedData),
  3. 對稱解密秘鑰 aeskey = Base64_Decode(session_key), aeskey 是16字節
  4. 對稱解密算法初始向量 iv 會在數據接口中返回。

微信官方提供了多種編程語言的示例代碼(點擊下載)。每種語言類型的接口名字均一致。調用方式可以參照示例。

這時候我們通過小程序得到的result.encryptedData與result.iv與后端得到的session_key 解密出我們得到的敏感用戶信息了。

官方給出的解密文檔:https://mp.weixin.qq.com/debug/wxadoc/dev/api/signature.html

以上所述是小編給大家介紹的微信小程序獲取用戶信息并保存登錄狀態詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 瓮安县| 新宁县| 军事| 林芝县| 朝阳区| 额济纳旗| 泽库县| 进贤县| 合作市| 德昌县| 洞口县| 怀安县| 壤塘县| 聂拉木县| 黑山县| 江西省| 蓝田县| 嘉禾县| 泗洪县| 饶平县| 日喀则市| 佛坪县| 晋城| 乐平市| 泰来县| 庐江县| 高邮市| 亳州市| 兴隆县| 河南省| 瑞昌市| 灵武市| 孙吴县| 农安县| 怀来县| 措美县| 榆中县| 星子县| 阳高县| 卢龙县| 都江堰市|