問題
由于wx.request()發起的每次請求對于服務器來說都是不同的會話(wx.request()請求是先經過微信服務器再到達我們的服務器),這樣會導致后續請求都相當于未登錄的狀態。
解決方案
將登陸時后端返回的session保存在本地,
然后將session存放在cookie中以請求頭的方式帶回給服務端
實現代碼
1.請求登陸接口獲取到header["Set-Cookie"],并儲存
//app.js
App({
onLaunch() {
wx.login({ // 登錄
// 發送 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.后續接口將儲存的sessionid放在cookie中以請求頭的方式帶回給服務端
//index.js
Page({
onLoad(options) {
wx.request({
url: api + '/list',
method: 'GET',
header: { //將sessionid放在cookie中以請求頭的方式帶回給服務端
'cookie': wx.getStorageSync("sessionid")
},
success(res) {
console.log(res);
}
})
}
})
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。