微信小程序 如何保持登錄狀態(tài)
問題
由于wx.request()發(fā)起的每次請求對于服務(wù)器來說都是不同的會話(wx.request()請求是先經(jīng)過微信服務(wù)器再到達(dá)我們的服務(wù)器),這樣會導(dǎo)致后續(xù)請求都相當(dāng)于未登錄的狀態(tài)。
解決方案
將登陸時后端返回的session保存在本地,
然后將session存放在cookie中以請求頭的方式帶回給服務(wù)端
實現(xiàn)代碼
1.請求登陸接口獲取到header["Set-Cookie"],并儲存
//app.js App({ onLaunch() { wx.login({ // 登錄 // 發(fā)送 res.code 到后臺換取 openId, sessionKey, unionId success: res => { wx.request({ url: 'api/login', method: 'POST', data: { code: res.code }, success(res) { //必須先清除,否則res.header['Set-Cookie']會報錯 wx.removeStorageSync('sessionid') ; //儲存res.header['Set-Cookie'] wx.setStorageSync("sessionid", res.header["Set-Cookie"]) ; } }); } }); } })
2.后續(xù)接口將儲存的sessionid放在cookie中以請求頭的方式帶回給服務(wù)端
//index.js Page({ onLoad(options) { wx.request({ url: api + '/list', method: 'GET', header: { //將sessionid放在cookie中以請求頭的方式帶回給服務(wù)端 'cookie': wx.getStorageSync("sessionid") }, success(res) { console.log(res); } }) } })
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript中保留兩位小數(shù)的方法總結(jié)
這篇文章主要把相關(guān)保留兩位小數(shù)的方法總結(jié)了一下,不同的場景用不同的方法,即用即取,文中的示例代碼講解詳細(xì),?感興趣的小伙伴可以了解一下2023-06-06cookie丟失問題(認(rèn)證失效) Authentication (用戶驗證信息)也會丟失
window.showModalDialog() 后 window.open() 導(dǎo)致cookie丟失問題(認(rèn)證失效) Authentication (用戶驗證信息)也會丟失2009-06-06JS實現(xiàn)頁面超時后自動跳轉(zhuǎn)到登陸頁面
這篇文章主要介紹了JS實現(xiàn)頁面超時后自動跳轉(zhuǎn)到登陸頁面,需要的朋友可以參考下2015-01-01JavaScript利用split函數(shù)按規(guī)定截取字符串(獲取郵箱用戶名)
這個其實就是利用了js的split函數(shù),以@分割數(shù)組,一般用這個的地方不多,但這個思路應(yīng)用的比較廣泛。推薦大家學(xué)習(xí)。2009-12-12學(xué)習(xí)JavaScript設(shè)計模式之模板方法模式
這篇文章主要為大家介紹了JavaScript設(shè)計模式中的模板方法模式,對JavaScript設(shè)計模式感興趣的小伙伴們可以參考一下2016-01-01