微信小程序用戶授權(quán)環(huán)節(jié)實現(xiàn)過程
在商城項目中,我們需要對部分的頁面,進行一個授權(quán)的判別,例如購物車,及個人中心,需要完成用戶信息的授權(quán)后,獲取到相關(guān)信息
因為不止一個頁面的跳轉(zhuǎn)需要此授權(quán)校驗的功能,所以我們選擇封裝一個授權(quán)校驗的公共組件,跳轉(zhuǎn)到需要驗證的頁面,需要進行授權(quán)登錄
公共組件權(quán)限判斷
封裝公共組件,在需要使用校驗的地方引入,進行判斷
邏輯判斷:
存入了手機號,則校驗中的回調(diào)函數(shù)允許執(zhí)行
未存入手機號,則先判斷有無存入微信授權(quán)信息,(有的話,去存手機號,沒有的話,先去存授權(quán)信息)
function CheckAuth(callback){ // wx.getStorageSync 獲取微信本地存儲 // 判斷是否有存入手機號進本地存儲 if(wx.getStorageSync('tel')){ //處理業(yè)務(wù) callback() }else{ // 沒有存入手機號,但是判斷是否有認證信息的 token if(wx.getStorageSync('token')){ wx.navigateTo({ url: '/pages/telform/telform', }) // 沒有存入手機號,也沒有 token 認證信息 }else{ wx.navigateTo({ url: '/pages/auth/auth', }) } } } export default CheckAuth
例如,shopcar 購物車組件:
校驗通過情況:(已登陸過)
在進行獲取購物車數(shù)據(jù)前,觸發(fā) CheckAuth( ),且傳入其中的回調(diào)函數(shù)為獲取對應(yīng)列表數(shù)據(jù),若有手機號,則運行執(zhí)行該回調(diào)函數(shù),獲取數(shù)據(jù),渲染數(shù)據(jù)
/*** 生命周期函數(shù)--監(jiān)聽頁面顯示*/ onShow() { // 驗證通過后可以觸發(fā)回調(diào)函數(shù) CheckAuth(()=>{ let {nickName} = wx.getStorageSync('token') let tel = wx.getStorageSync('tel') request({ url:`/carts?_expand=good&username=${nickName}&tel=${tel}` }).then(res=>{ this.setData({ cartList:res }) }) }) },
校驗未通過情況:(未存入任何信息,首次登陸)
未獲取到本地的存儲授權(quán)信息及賬號信息,則進行頁面的跳轉(zhuǎn),跳轉(zhuǎn)至授權(quán)頁面
function CheckAuth(callback){ // 已存入過手機號,直接可獲取數(shù)據(jù) if(wx.getStorageSync('tel')){ //處理業(yè)務(wù) callback() } // 沒有存入手機號,但是判斷是否有認證信息的 token else{ if(wx.getStorageSync('token')){ wx.navigateTo({ url: '/pages/telform/telform', }) } // 沒有存入手機號,也沒有 token 認證信息 else{ wx.navigateTo({ url: '/pages/auth/auth', }) } } }
微信授權(quán)驗證wx.getUserProfile()
使用 wx.getUserProfile( ) 獲取當(dāng)前微信的信息
驗證成功后,在成功回調(diào)函數(shù)里存儲 token 信息,再次跳轉(zhuǎn)至手機號存儲頁面
// 獲取 微信授權(quán) 驗證 handleAuth(){ wx.getUserProfile({ desc: '用于完善會員資料', success:(res)=>{ wx.setStorageSync('token', res.userInfo) wx.navigateTo({ url: '/pages/telform/telform', }) } }) },
手機號帳號信息驗證
頁面結(jié)構(gòu):
<mp-form-page title="綁定手機號" subtitle="驗證微信賬號后需要綁定手機號"> <mp-cells title="信息"> <mp-cell> <input class="weui-input" placeholder="請輸入手機號" bindinput="formInputChange" /> <view slot="footer" class="weui-vcode-btn">獲取驗證碼</view> </mp-cell> </mp-cells> <view slot="button"> <button class="weui-btn" type="primary" bindtap="submitForm">確定</button> </view> </mp-form-page>
引入 WeUI:
{ "usingComponents": { "mp-form-page": "weui-miniprogram/form-page/form-page", "mp-form": "weui-miniprogram/form/form", "mp-cells": "weui-miniprogram/cells/cells", "mp-cell": "weui-miniprogram/cell/cell" }, "navigationBarTitleText": "手機號綁定" }
提交手機號:
未存入過信息,使用 post 請求存入新數(shù)據(jù),跳轉(zhuǎn)回正常使用頁面
存入過了信息,不再重復(fù)存,跳轉(zhuǎn)回正常使用頁面
跳轉(zhuǎn)返回頁面:wx.navigateBack()
// 點擊確定 提交手機號 submitForm(){ // 手機號存入本地 wx.setStorageSync('tel', this.data.tel) // 試著去數(shù)據(jù)庫找一下,相同 手機號 和 微信驗證 的數(shù)據(jù)是否有 request({ url:`/users?tel=${this.data.tel}&nickName=${wx.getStorageSync('token').nickName}` }).then(res=>{ // 數(shù)據(jù)庫未存過信息,post請求,去數(shù)據(jù)庫中新建一個數(shù)據(jù),帶上token和手機號 if(res.length===0) { request({ url:`/users`, method:'post', data:{ ...wx.getStorageSync('token'), tel:this.data.tel } }).then(res=>{ // 回退兩級,返回到 購物車 或 個人中心 wx.navigateBack({ delta:2 }) }) } // 數(shù)據(jù)庫存過信息,就不再重復(fù)存入,跳轉(zhuǎn)回正常頁面使用即可 else { wx.navigateBack({ delta:2 }) } }) },
到此這篇關(guān)于微信小程序用戶授權(quán)環(huán)節(jié)實現(xiàn)過程的文章就介紹到這了,更多相關(guān)小程序用戶授權(quán)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js實現(xiàn)當(dāng)鼠標(biāo)移到表格上時顯示這一格全部內(nèi)容的代碼
下面小編就為大家?guī)硪黄猨s實現(xiàn)當(dāng)鼠標(biāo)移到表格上時顯示這一格全部內(nèi)容的代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06vscode?對?typescript代碼調(diào)試的步驟
在VS?Code中,要對?TypeScript代碼進行調(diào)試,需要先編譯?TypeScript?代碼為JavaScript代碼,這篇文章主要介紹了vscode對typescript代碼調(diào)試的方法,需要的朋友可以參考下2023-03-03JavaScript使用performance實現(xiàn)查看內(nèi)存
這篇文章主要為大家詳細介紹了JavaScript如何使用performance實現(xiàn)查看內(nèi)存,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03BootstrapValidator不觸發(fā)校驗的實現(xiàn)代碼
BootstrapValidator是基于bootstrap3的jquery表單驗證插件,是最適合bootstrap框架的表單驗證插件,本文給大家介紹BootstrapValidator不觸發(fā)校驗的實現(xiàn)代碼,感興趣的朋友一起看看吧2016-09-09