您好,登錄后才能下訂單哦!
這篇文章主要介紹微信小程序中授權登錄的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
公司業務開展,最近完成了一個微信小程序的開發。場景是這樣:同一微信開放平臺下擁有相同主體的APP和微信小程序來完成同樣的業務,用戶進入app或者微信小程序時必須獲取用戶的unionid來確認當前的用戶身份,完成登錄。小程序“獲取用戶信息”api(getUserInfo)的調用方式和之前相比有了較大更新,優雅的實現用戶授權和登錄非常重要,以下是我在微信小程序授權登錄相關流程在開發時候的實現思路和總結,分享如下。
說明:
小程序調用wx.login() 獲取 臨時登錄憑證code ,并回傳到開發者服務器
開發者服務器以code換取 用戶唯一標識openid 和 會話密鑰session_key。
臨時登錄憑證code只能使用一次
在關注者與公眾號產生消息交互后,公眾號可獲得關注者的OpenID(加密后的微信號,每個用戶對每個公眾號的OpenID是唯一的。對于不同公眾號,同一用戶的openid不同)。——微信公眾平臺開發者文檔
普通用戶的標識,對當前公眾號唯一
不同的公眾號,同一個用戶,openid不同
你可以簡單的理解為
openid = hash(uid + app_id)
如果開發者擁有多個移動應用、網站應用、和公眾帳號(包括小程序),可通過unionid來區分用戶的唯一性,因為只要是同一個微信開放平臺帳號下的移動應用、網站應用和公眾帳號(包括小程序),用戶的unionid是唯一的。換句話說,同一用戶,對同一個微信開放平臺下的不同應用,unionid是相同的。UnionID機制說明
如果開發者在多個移動應用、網站應用和公眾帳號之間有統一用戶賬號的需求,需要前往微信開放平臺(open.weixin.qq.com)綁定公眾號后,便可利用UnionID機制來滿足上述需求。
一個微信開放平臺帳號下可以有多個移動應用,網站應用,公眾賬號和小程序
只要是同一個微信開放平臺帳號下的移動應用、網站應用和公眾帳號(包括小程序),用戶的unionid是唯一的。
用戶在開放平臺的唯一標識符
你可以簡單的理解為:
unionid = hash(uid + 開放平臺id)
總結下
微信針對不同的用戶在不同的應用下都有唯一的一個openId, 但是要想確定用戶是不是同一個用戶,就需要靠unionid來區分。一般自己的后臺都會有自己的一個用戶表,每個用戶有不同的userid。也就是說同一個用戶在同一個微信開放平臺下的相同主體的應用對應著相同的userid,unionid以及不同的openid。所以在用戶登錄進來的時候,我們只能靠微信返回給我們的unionid去判斷是不是同一個用戶,在去關聯我們的用戶表,拿到對應的userid。
綁定了開發者帳號的小程序,可以通過下面3種途徑獲取UnionID。
調用接口wx.getUserInfo,從解密數據中獲取UnionID。注意本接口需要用戶授權,請開發者妥善處理用戶拒絕授權后的情況。
如果開發者帳號下存在同主體的公眾號,并且該用戶已經關注了該公眾號。開發者可以直接通過wx.login獲取到該用戶UnionID,無須用戶再次授權。
如果開發者帳號下存在同主體的公眾號或移動應用,并且該用戶已經授權登錄過該公眾號或移動應用。開發者也可以直接通過wx.login獲取到該用戶UnionID,無須用戶再次授權。
當用戶滿足條件2和3時,開發者可以直接通過wx.login獲取到該用戶的unionid, 否則必須調用接口wx.getUserInfo
,額外需要注意的事就是妥善處理用戶拒絕授權的情況。
調用 wx.login 獲取 code。
使用 wx.getSetting 獲取用戶的授權情況
如果用戶已經授權,直接調用 API wx.getUserInfo 獲取用戶最新的信息;
用戶未授權,在界面中顯示一個按鈕提示用戶登入,當用戶點擊并授權后就獲取到用戶的最新信息。
將獲取到的用戶數據連同wx.login返回的code一同傳給后端
在真實的業務場景中,我們希望,用戶進入小程序時,未登錄情況下可以正常瀏覽商品,對小程序有個基本的認知,不要直接彈出框要求用戶授權,否則會干擾用戶,導致新用戶的流失,當用戶需要使用一些高級功能和場景,這個時候再去要求用戶授權,這樣用戶授權的幾率會大大提高。
將登錄的邏輯封裝ajax
流程:
封裝的意義
不再關注當前接口是否需要登錄,用戶是否已授權,所有請求直接調用ajax()
,在必要的時候完成一切登錄以及授權流程。小程序入口頁面增加,業務拓展的時候,你只需要專注于業務實現。
以上是“微信小程序中授權登錄的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。