網站首頁 編程語言 正文
這幾天是疫情期間,老板為了配合我們公司的線上產品,讓我們技術人員開發了一個簡單的小程序,在開發過程中,就提到了獲取用戶手機號碼的需求,然后我查閱了微信小程序開發文檔,由此,我想記錄一下,方便我以后查閱
首先,思路要明確,要想獲取手機號碼,那我們就得微信授權,微信授權的話,那我們就得獲取微信的登錄,所以第一步,調用微信登錄的api:
wx.login({
success (res) {
if (res.code) {
//發起網絡請求
wx.request({
url: 'https://test.com/onLogin',
data: {
code: res.code
}
})
} else {
console.log('登錄失敗!' + res.errMsg)
}
}
})
然后,我們將獲取到的code,發送給后臺,后臺會返回一個oppenId給前端,然后我們開始調用獲取手機號碼的api
官方文檔說的很詳細
getPhoneNumber (e) {
console.log(e.detail.iv)
console.log(e.detail.encryptedData)
if(e.detail.iv)){//表示授權成功,自己可以測試一下,成功后就可以發送請求給后臺,獲取解密 后的手機號碼
}
}
此處還有一個問題,就是授權成功的前提,需要登錄,一開始,我是在獲取手機號碼的地方,先登錄,登錄成功后,我在手機號碼進行授權的,但是這樣會存在問題, 當時報了英文錯誤
The given payload is invalid
其實這個錯誤,官方文檔給了注意,當時自己沒有留意這些在重點突出一下
在回調中調用 wx.login 登錄,可能會刷新登錄態。此時服務器使用 code 換取的 sessionKey 不是加密時使用的 sessionKey,導致解密失敗。建議開發者提前進行 login;或者在回調中先使用 checkSession 進行登錄態檢查,避免 login 刷新登錄態。
所以最好將登錄放在周期函數onload()里面,然后就不會出現這個問題了,為了避免重復登錄,我們可以將登錄寫在checkSesson里面
wx.checkSession({
success () {
//session_key 未過期,并且在本生命周期一直有效
},
fail () {
// session_key 已經失效,需要重新執行登錄流程
wx.login({
success (res) {
if (res.code) {
//發起網絡請求-獲取openId等參數,存儲起來
wx.request({
url: 'https://hdxcx.cdamai.com/wechat/login',
method: 'POST',
data: {
code: res.code,
scene:decodeURIComponent(options.scene)
},
header: {
'content-type':'application/x-www-form-urlencoded',
'Accept': 'application/json'
},
success (res) {
let code = res.data.code;
if(code == "0"){
wx.setStorageSync('openId',res.data.data.openid);
}else{
wx.showToast({
title:'登錄失敗',
icon: 'none',
duration: 2000
});
}
}
},
)
} else {
console.log('登錄失敗!' + res.errMsg)
}
}
})
}
})
別的好像沒什么可記錄的了,后期遇到問題,我會慢慢補充的
原文鏈接:https://blog.csdn.net/Fiona_lms/article/details/104423452
- 上一篇:微信小程序:返回上一頁,刷新頁面內容
- 下一篇:css :清除a元素的默認間距
相關推薦
- 2022-11-07 WPF使用DrawingContext實現繪制刻度條_C#教程
- 2022-06-08 Jenkins集成Gitlab實現自動化部署的全過程記錄_相關技巧
- 2022-12-09 C++實現雙向起泡排序算法_C 語言
- 2022-12-10 Qt如何自定義滑動條_C 語言
- 2022-01-17 類組件與函數組件的區別 react中class創建的組件與function創建的組件有什么區別
- 2022-12-05 useReducer?createContext代替Redux原理示例解析_React
- 2022-04-08 WPF中Style樣式及其觸發器_基礎應用
- 2022-08-14 如何關閉Hyper-v虛擬服務_Hyper-V
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支