微信用戶訪問小程序的登錄過程詳解
概述
當(dāng)你開發(fā)完了一個(gè)小程序并部署上線后,某個(gè)微信用戶第一次訪問這個(gè)小程序的時(shí)候,會(huì)彈出一個(gè)授權(quán)界面,用戶可以選擇是否使用微信登錄,如果選擇是,則直接進(jìn)入到小程序。當(dāng)你第二次進(jìn)入該小程序的時(shí)候,你會(huì)發(fā)現(xiàn)授權(quán)界面不會(huì)彈出來了,直接就進(jìn)入小程序了。
這個(gè)過程看起來非常的簡(jiǎn)單,但其實(shí)實(shí)現(xiàn)起來相當(dāng)?shù)穆闊┖头爆?。涉及到?huì)話、安全、驗(yàn)證等各種各樣的問題。下面筆者介紹一下實(shí)現(xiàn)這個(gè)登錄過程的思路。
微信提供小程序登錄流程圖

我們可以從登錄流程時(shí)序 找到這張圖。想完全看懂張圖,需要了解很多東西。我們先來看看微信提供的幾個(gè)接口。
小程序接口介紹
wx.login()
這個(gè)方法是小程序端發(fā)起的,如果是使用騰訊團(tuán)隊(duì)推出的小程序組件化開發(fā)框架的wepy的話,偽代碼如下:
wepy.login()
.then(res => {
const code = res.code
})
這樣子就可以從微信平臺(tái)獲取一個(gè)code,這個(gè)code是臨時(shí)登錄憑證,用于獲取openid的。
wx.request()
這個(gè)也是小程序端發(fā)起的,用于請(qǐng)求開發(fā)者服務(wù)器(也即是我們的應(yīng)用服務(wù)器)上的接口,調(diào)用的偽代碼如下:
wepy.request({
url: `xxurl`,
data: {
//入?yún)?
},
})
.then(res => {
//從res中獲取應(yīng)用服務(wù)器返回的數(shù)據(jù)
})
獲取openid的接口
當(dāng)某個(gè)開發(fā)主體開發(fā)了一個(gè)小程序后,當(dāng)用戶訪問這個(gè)小程序的時(shí)候,微信平臺(tái)會(huì)為這個(gè)用戶分配一個(gè)openid。如下接口:
https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code
這個(gè)微信接口一般是我們的應(yīng)用服務(wù)器發(fā)起調(diào)用的,而不是小程序端發(fā)起的。
wx.getUserInfo
getUserInfo這個(gè)接口用于在微信平臺(tái)獲取用戶信息。注意,如果微信用戶第一次訪問小程序,是彈出一個(gè)授權(quán)界面的。當(dāng)用戶授權(quán)后,getUserInfo才能調(diào)用并返回用戶數(shù)據(jù)。
這個(gè)四個(gè)接口在使用微信訪問小程序的時(shí)候都會(huì)用到的。
基于token保持會(huì)話和登錄認(rèn)證
小程序雖然不支持cookie的機(jī)制,但是支持在header里設(shè)置token。
這個(gè)token是應(yīng)用服務(wù)器生成的。
header: {
'xxxxtoken': token,
}
當(dāng)小程序調(diào)用應(yīng)用服務(wù)器接口的時(shí)候,必須帶上這個(gè)token,應(yīng)用服務(wù)端則對(duì)這個(gè)token進(jìn)行解析和認(rèn)證。當(dāng)然如果是第一次訪問小程序,只能由應(yīng)用服務(wù)器先生成token。 筆者打算用偽代碼來表達(dá)使用token后,整個(gè)登錄的過程,因?yàn)橛梦淖只蛘邎D比較難表達(dá)。
const code = wx.login();
if (code ) {//code存在
//從小程序的本地中獲取toten
const token = wx.getStorageSync('xxxxxtoken')
if (token ) {//小程序本地存有token,無需彈出授權(quán)界面
//直接傳入code字段,調(diào)用應(yīng)用服務(wù)器的驗(yàn)證token的方法,如果校驗(yàn)成功,需要返回用戶信息。
const userinfo = wx.request(http://xxxxxValidateToken(code ));
if (userinfo) {
//說明登錄成功,直接進(jìn)入小程序的主界面。
}
}
else {
//說明小程序本地沒有token,這個(gè)時(shí)候需要彈出授權(quán)界面,讓微信用戶決定是否訪問小程序,如果用戶選擇是的話。
const weixinuserinfo = wx.getUserInfo();//會(huì)彈出授權(quán)界面,微信提供的
if (weixinuserinfo ){
//生成或者驗(yàn)證token
const userinfo = wx.request(http://xxxxxValidateToken(code ));
const token = userinfo.getToken();
//將token存儲(chǔ)到小程序本地
wx.setStorageSync('xxxxxtoken', token )
}
}
}
上面的偽代碼中,會(huì)調(diào)用應(yīng)用服務(wù)器(我們的應(yīng)用服務(wù)器)的
http://xxxxxValidateToken(code )
方法。這個(gè)方法的實(shí)現(xiàn)邏輯大概如下:
1、先驗(yàn)證這個(gè)微信用戶是否存在,可以調(diào)用微信提供的jscode2session方法,該方法會(huì)返回一個(gè)openid。我們必須在業(yè)務(wù)代碼里,將這個(gè)openid保存到數(shù)據(jù)庫,并和userid關(guān)聯(lián)起來。
2、判斷是否是新的用戶,如果是,則生成token和生成新的一個(gè)用戶信息存儲(chǔ)到數(shù)據(jù)庫。如果不是新的用戶,則驗(yàn)證token。
這個(gè)流程走完后,小程序就可以通過wx.request方法,帶上token,真正的訪問應(yīng)用服務(wù)器的業(yè)務(wù)方法,獲取業(yè)務(wù)數(shù)據(jù)。
token的生成和校驗(yàn)
見過有些公司是直接將userid和openid,加密后返回給小程序。也見過用userid和password加密后返回給小程序。如果是選擇第二種方式的話,驗(yàn)證token的邏輯大概如下:
先解密,獲取userid和password,并根據(jù)userid從數(shù)據(jù)庫中獲取到用戶密碼,跟從token中解密出來的password進(jìn)行比對(duì),如果相等,則校驗(yàn)通過。
總結(jié)
現(xiàn)在再回頭看看微信提供登錄路程圖,是否好理解一些了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js獲取元素的外鏈樣式的簡(jiǎn)單實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猨s獲取元素的外鏈樣式的簡(jiǎn)單實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06
使用 bootstrap modal遇到的問題小結(jié)
bootstrap提供了一個(gè)寫好的css文件和js文件然而在使用時(shí)遇到了一下并不是很好的問題,今天在使用彈出對(duì)話框時(shí)遇到了一個(gè)這樣的問題,今天小編給大家分享下使用 bootstrap modal遇到的問題小結(jié),一起看看吧2016-11-11
移動(dòng)端a標(biāo)簽下載文件重命名(download)不生效解決辦法
在移動(dòng)端使用a標(biāo)簽下載文件時(shí),文件重命名可能不生效,尤其是在APP內(nèi)嵌頁面中,這通常是因?yàn)榭缬騿栴}導(dǎo)致的,文中將解決辦法介紹的非常詳細(xì),需要的朋友可以參考下2024-10-10
JavaScript字符串操作的四個(gè)實(shí)用技巧
在制作前端頁面的過程中,經(jīng)常需要用到JavaScript進(jìn)行邏輯處理,很多時(shí)候都需要對(duì)字符串進(jìn)行操作,這篇文章主要給大家介紹了關(guān)于JavaScript字符串操作的四個(gè)實(shí)用技巧,需要的朋友可以參考下2021-07-07
JavaScript?WebSocket實(shí)現(xiàn)實(shí)時(shí)雙向聊天
這篇文章主要為大家詳細(xì)介紹了如何基于JavaScript?WebSocket實(shí)現(xiàn)實(shí)時(shí)雙向聊天,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考一下2024-04-04

