uni-app微信小程序登錄授權的實現(xiàn)
微信小程序授權是非常簡單和常用的功能,但為了方便,還是在此記錄一下要點:
首先是需要用到一個授權按鈕來觸發(fā)獲取用戶信息授權: 關鍵在于 open-type 為 getUserInfo , 然后有個@getuserinfo的事件,把獲取授權接口寫到該事件里面去
<button class="sys_btn" open-type="getUserInfo" lang="zh_CN" @getuserinfo="appLoginWx">{{loginInfo.openid != "" && loginInfo.openid != undefined ? "已授權" : "小程序授權"}}</button>
方法如下:
appLoginWx(){ // #ifdef MP-WEIXIN uni.getProvider({ service: 'oauth', success: function (res) { if (~res.provider.indexOf('weixin')) { uni.login({ provider: 'weixin', success: (res) => { _self.authorization = res.code; uni.getUserInfo({ provider: 'weixin', success: (info) => {//這里請求接口 console.log(res); console.log(info); }, fail: () => { uni.showToast({title:"微信登錄授權失敗",icon:"none"}); } }) }, fail: () => { uni.showToast({title:"微信登錄授權失敗",icon:"none"}); } }) }else{ uni.showToast({ title: '請先安裝微信或升級版本', icon:"none" }); } } }); //#endif }
在 uni.login 和 uni.getUserInfo 被調用后,你可以獲取到以下值用于繼續(xù)請求后端給你的接口:
常用的值大概有:code 、iv 、encryptedData 和 個人基本信息,這些可以傳給后端交換得到openid。
如果需要知道用戶當前是否已經(jīng)授權,則可以使用如下代碼:
uniapp的授權文檔,可以判斷不同的授權類型:https://uniapp.dcloud.io/api/other/authorize?id=authorize
// #ifdef MP-WEIXIN uni.getSetting({ success(res) { console.log("授權:",res); if (!res.authSetting['scope.userInfo']) { //這里調用授權 console.log("當前未授權"); } else { //用戶已經(jīng)授權過了 console.log("當前已授權"); } } }) //#endif
到此這篇關于uni-app微信小程序登錄授權的實現(xiàn)的文章就介紹到這了,更多相關uni-app小程序登錄授權內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
js String.prototype.trim字符去前后空格的擴展
這篇文章主要介紹了js String.prototype.trim字符去前后空格的擴展,需要的朋友可以參考下2020-04-04js 頁面?zhèn)鲄?shù)時 參數(shù)值含特殊字符的問題
解決方法就是利用js的escape函數(shù),這個函數(shù)在解決中文亂碼等方面應用的比較廣泛。推薦使用。2009-12-12微信小程序自定義select下拉選項框組件的實現(xiàn)代碼
微信小程序中沒有select下拉選項框,所以只有自定義。這篇文章主要介紹了微信小程序自定義select下拉選項框組件,需要的朋友可以參考下2018-08-08