微信小程序如何通過(guò)用戶授權(quán)獲取手機(jī)號(hào)(getPhoneNumber)
這篇文章主要介紹了微信小程序如何通過(guò)用戶授權(quán)獲取手機(jī)號(hào)(getPhoneNumber),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
小程序有一個(gè)獲取用戶很便捷的api,就是通過(guò)getPhoneNumber獲取用戶的已經(jīng)綁定微信的手機(jī)號(hào)碼。有一點(diǎn)要大家注意,現(xiàn)在微信和注重用戶體驗(yàn),有些方法都是需要用戶主動(dòng)去觸發(fā)才能調(diào)用的,比如getPhoneNumber。
官方文檔:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html
實(shí)現(xiàn)思路:
直接上干貨:
1、
<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button>
2、JS內(nèi)getPhoneNumbe組件函數(shù)(該事件中最重要的就是在wx.login登錄后發(fā)起接口請(qǐng)求),這里需要配置參數(shù)來(lái)給接口:
這些是必不可少的參數(shù),這些齊備才能算一個(gè)合法的請(qǐng)求。
appid: “你的小程序APPID”, secret: “你的小程序appsecret”, code: res.code, encryptedData: telObj, iv: ivObj
//通過(guò)綁定手機(jī)號(hào)登錄 getPhoneNumber: function (e) { var ivObj = e.detail.iv var telObj = e.detail.encryptedData var codeObj = ""; var that = this; //------執(zhí)行Login--------- wx.login({ success: res => { console.log('code轉(zhuǎn)換', res.code); //用code傳給服務(wù)器調(diào)換session_key wx.request({ url: 'https://你的接口文件路徑', //接口地址 data: { appid: "你的小程序APPID", secret: "你的小程序appsecret", code: res.code, encryptedData: telObj, iv: ivObj }, success: function (res) { phoneObj = res.data.phoneNumber; console.log("手機(jī)號(hào)=", phoneObj) wx.setStorage({ //存儲(chǔ)數(shù)據(jù)并準(zhǔn)備發(fā)送給下一頁(yè)使用 key: "phoneObj", data: res.data.phoneNumber, }) } }) //-----------------是否授權(quán),授權(quán)通過(guò)進(jìn)入主頁(yè)面,授權(quán)拒絕則停留在登陸界面 if (e.detail.errMsg == 'getPhoneNumber:user deny') { //用戶點(diǎn)擊拒絕 wx.navigateTo({ url: '../index/index', }) } else { //允許授權(quán)執(zhí)行跳轉(zhuǎn) wx.navigateTo({ url: '../test/test', }) } } }); },
最終結(jié)果展示:
點(diǎn)擊"拒絕",開(kāi)發(fā)者能捕捉到該事件 ,此時(shí)getPhoneNumber 函數(shù)返回 e.detail.errMsg 為 getPhoneNumber:user deny
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript canvas實(shí)現(xiàn)簡(jiǎn)易時(shí)鐘例子
這篇文章主要為大家詳細(xì)介紹了javascript canvas實(shí)現(xiàn)簡(jiǎn)易時(shí)鐘例子,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09javascript中Array數(shù)組的迭代方法實(shí)例分析
這篇文章主要介紹了javascript中Array數(shù)組的迭代方法,實(shí)例分析了Array數(shù)組的迭代方法定義與使用技巧,需要的朋友可以參考下2015-02-02JavaScript之class繼承_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了JavaScript之class繼承,新的關(guān)鍵字class從ES6開(kāi)始正式被引入到JavaScript中。class的目的就是讓定義類更簡(jiǎn)單,有興趣的可以了解一下2017-07-07JS實(shí)現(xiàn)無(wú)限輪播無(wú)倒退效果
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)無(wú)限輪播無(wú)倒退效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09談?wù)別ncodeURI和encodeURIComponent以及escape的區(qū)別與應(yīng)用
encodeURI和encodeURIComponent以及escape,這三個(gè)都是用來(lái)編碼的,本篇文章給大家介紹encodeURI和encodeURIComponent以及escape的區(qū)別與應(yīng)用,感興趣的朋友一起學(xué)習(xí)吧2015-11-11webpack實(shí)現(xiàn)一個(gè)行內(nèi)樣式px轉(zhuǎn)vw的loader示例
這篇文章主要介紹了webpack實(shí)現(xiàn)一個(gè)行內(nèi)樣式px轉(zhuǎn)vw的loader示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09