知識
不管是網(wǎng)站,軟件還是小程序,都要直接或間接能為您產(chǎn)生價值,我們在追求其視覺表現(xiàn)的同時,更側(cè)重于功能的便捷,營銷的便利,運營的高效,讓網(wǎng)站成為營銷工具,讓軟件能切實提升企業(yè)內(nèi)部管理水平和效率。優(yōu)秀的程序為后期升級提供便捷的支持!
您當(dāng)前位置>首頁 » 新聞資訊 » 小程序相關(guān) >
一文詳解小程序授權(quán)、登錄、session_key和unionId
發(fā)表時間:2021-1-5
發(fā)布人:葵宇科技
瀏覽次數(shù):80
授權(quán)和登錄的意義
session_key 的作用
unionId 的作用,有哪些獲取途徑
在應(yīng)用中如何保存用戶登錄態(tài)
1
授權(quán)和登錄的意義
首先必須要明白,授權(quán)和登錄實際上是兩個操作。
1.1 授權(quán)
那授權(quán)的作用是啥呢?從小程序官方文檔中我們可以看到授權(quán)操作只需通過wx.authorize() 接口便可以完成,以下是文檔中對授權(quán)操作的描述:
提前向用戶發(fā)起授權(quán)請求。調(diào)用后會立刻彈窗詢問用戶是否同意授權(quán)小程序使用某項功能或獲取用戶的某些數(shù)據(jù),但不會實際調(diào)用對應(yīng)接口。如果用戶之前已經(jīng)同意授權(quán),則不會出現(xiàn)彈窗,直接返回成功。
也就是說,授權(quán)過程實際上只是在小程序前端獲得了操作部分wx 接口的訪問許可,這個過程實際上是不會與開發(fā)者服務(wù)器發(fā)生任何關(guān)系的。那這些訪問許可包含哪些內(nèi)容呢?再來看微信官方提供的scope 列表:
注:新版api已廢棄wx.authorize()
1.2 登錄
所謂的登錄就是要讓開發(fā)者服務(wù)器知道當(dāng)前的用戶是誰?在傳統(tǒng)的web 應(yīng)用中,我們必須要讓用戶輸入賬號和密碼才能實現(xiàn)登錄操作。但是在微信應(yīng)用中,我們可以通過微信服務(wù)器來完成這個操作,獲取到與當(dāng)前用戶對應(yīng)的唯一標(biāo)志(openId),具體操作實現(xiàn)流程如下:
wx.login()用來做登錄的方法,調(diào)用接口獲取登錄憑證,code發(fā)送給后端用于置換session_key和openid等數(shù)據(jù)。每個用戶相對于每個微信應(yīng)用(公眾號或者小程序)的openId 是唯一的,也就是說一個用戶相對于不同的微信應(yīng)用會存在不同的openId。
這是小程序官方的一張登錄流程圖,現(xiàn)在就來解讀一下這個流程
前端wx.login()獲取code,調(diào)用后端接口,將得到的code發(fā)送到后端
后端調(diào)用微信接口,用appid+appsecret+code發(fā)送過去,置換到session_key+openid,以前是不能置換unionid的,但是現(xiàn)在在滿足以下條件可以置換到unionid
微信開放平臺下存在同主體的App、公眾號、小程序
用戶關(guān)注了某個相同主體公眾號,或曾經(jīng)在某個相同主體App、公眾號上進(jìn)行過微信登錄授權(quán) 同時滿足以上兩個條件就能拿到用戶unionid,這樣一來,就能在wx.login()準(zhǔn)確識別出用戶是誰
自定登錄態(tài)與openid和session_key關(guān)聯(lián),實際就是生成一個與openid,session_key關(guān)聯(lián)的token,下發(fā)給前端
前端將后端下發(fā)的token存入緩存,在后面的接口請求中帶上自定登錄態(tài)
以上就是小程序的整個登錄流程,可以看到其實并不是一定要wx.getUserInfo()才能拿到用戶的信息,在特定的條件下,通過wx.login()的調(diào)用拿到unionId也能后端數(shù)據(jù)庫里拿到用戶信息。登錄過程中涉及session_key和unionId,于是又引出了下面的問題。
2
session_key 的作用
那么,session_key在登錄的過程中或者登錄完成后起什么作用呢?一起來看一下。
2.1 wx.getUserInfo
首先來看一下wx.getUserInfo 這個api:
在設(shè)置withCredentials 屬性為true 的情況下,這個api 可以拿到encryptedData,iv 等敏感信息,encryptedData 需要使用session_key 進(jìn)行解密,解密后可以拿到的數(shù)據(jù)如下:
也就是說,session_key的作用之一是將小程序前端從微信服務(wù)器獲取到的encryptedData 解密出來,獲取到openId 和unionId等信息。
但是在1.2登錄過程中可以看到開發(fā)者服務(wù)器是能夠直接拿到用戶的openId信息,而且unionId 也是有其他獲取途徑,所以session_key 在這里的作用看起來有點雞肋。
2.2 getPhoneNumber
session_key 更重要的作用大概體現(xiàn)在獲取用戶手機(jī)方面(可能還包含其他敏感信息獲取api)。
從文檔中可以看到getPhoneNumber 返回的用戶數(shù)據(jù)是加密過的,只有使用session_key才能解密,而小程序前端沒有session_key,所以無法獲取到用戶的手機(jī),只能傳到開發(fā)者服務(wù)器進(jìn)行處理。
3
unionId 的作用,有哪些獲取途徑?
3.1、UnionID機(jī)制說明
如果公司擁有多個移動應(yīng)用、網(wǎng)站應(yīng)用、和公眾帳號(包括小程序),可通過unionid來區(qū)分用戶的唯一性,因為只要是同一個微信開放平臺帳號下的移動應(yīng)用、網(wǎng)站應(yīng)用和公眾帳號(包括小程序),用戶的unionid是唯一的。換句話說,同一用戶,對同一個微信開放平臺下的不同應(yīng)用,unionid是相同的。
Tip:unionid 用于識別同一主體下不同賬號之間的用戶。舉例說明:就是公司有A訂閱號,B服務(wù)號,同一個人關(guān)注A和B,會得到不同的OPENID,但是會得到相同的unionid。這樣就可以識別到相同的用戶,用于不同賬號之間打通用戶關(guān)系。
3.2、UnionID獲取途徑
必須有一個微信開放平臺賬號綁定了至少一個微信公眾賬號或者網(wǎng)站應(yīng)用或者小程序,否則UnionID返回null。綁定了開發(fā)者帳號的小程序,可以通過下面3種途徑獲取UnionID。
方法一:調(diào)用接口wx.getUserInfo,從解密數(shù)據(jù)中獲取UnionID。注意本接口需要用戶授權(quán),請開發(fā)者妥善處理用戶拒絕授權(quán)后的情況。
方法二:如果開發(fā)者帳號下存在同主體的公眾號,并且該用戶已經(jīng)關(guān)注了該公眾號。開發(fā)者可以直接通過wx.login獲取到該用戶UnionID,無須用戶再次授權(quán)。
方法三:如果開發(fā)者帳號下存在同主體的公眾號或移動應(yīng)用,并且該用戶已經(jīng)授權(quán)登錄過該公眾號或移動應(yīng)用。開發(fā)者也可以直接通過wx.login獲取到該用戶UnionID,無須用戶再次授權(quán)。
4
在應(yīng)用中如何保存用戶登錄態(tài)
保存用戶登錄態(tài),一直以來都有兩種解決方案:前端保存和后端保存。
4.1 后端保存
在1.2 步驟③ 中寫session 的時候可以直接設(shè)定過期時間,定期通知小程序前端重新進(jìn)行登錄(wx.login)。
4.2 前端保存
因為session_key 存在時效性問題(畢竟是用來查看敏感信息),而小程序前端可以通過wx.checkSession() 來檢查session_key 是否過期。所以可以通過這個來作為保存用戶登錄態(tài)的機(jī)制,這也是小程序文檔中推薦的方法:
相關(guān)案例查看更多
相關(guān)閱讀
- 百度小程序
- 云南網(wǎng)站建設(shè)
- 網(wǎng)絡(luò)公司聯(lián)系方式
- 汽車報廢回收管理系統(tǒng)
- 云南網(wǎng)站建設(shè)百度官方
- APP
- 汽車報廢管理
- 網(wǎng)站建設(shè)需要多少錢
- 云南網(wǎng)站建設(shè)公司
- 云南小程序開發(fā)公司哪家好
- 報廢車拆解回收管理系統(tǒng)
- 小程序開發(fā)平臺前十名
- 網(wǎng)站建設(shè)快速優(yōu)化
- 云南花農(nóng)小程序
- 云南做軟件
- 網(wǎng)站建設(shè)選
- typescript
- 云南網(wǎng)站建設(shè)哪家強(qiáng)
- 表單
- 云南小程序被騙
- 商標(biāo)注冊
- 小程序的開發(fā)公司
- 服務(wù)器
- 汽車回收管理系統(tǒng)
- 云南手機(jī)網(wǎng)站建設(shè)
- 小程序表單
- 云南網(wǎng)站建設(shè)靠譜公司
- 跳轉(zhuǎn)小程序
- uniapp開發(fā)小程序
- 智慧農(nóng)貿(mào)市場