问题
由于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.html" target="_blank">js Page({ onLoad(options) { wx.request({ url: api + '/list', method: 'GET', header: { //将sessionid放在cookie中以请求头的方式带回给服务端 'cookie': wx.getStorageSync("sessionid") }, success(res) { console.log(res); } }) } })
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍微信小程序获取用户信息并保存登录状态详解,包括了微信小程序获取用户信息并保存登录状态详解的使用技巧和注意事项,需要的朋友参考一下 前言 微信小程序的运行环境不是在浏览器下运行的。所以不能以cookie来维护登录态。下面我就来说说我根据官方给出的方法来写出的维护登录态的方法吧。 一、登录态维护 官方的文档地址:https://mp.weixin.qq.com/debug/wxadoc/
本文向大家介绍微信小程序登录数据解密及状态维持实例详解,包括了微信小程序登录数据解密及状态维持实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了微信小程序登录数据解密及状态维持。分享给大家供大家参考,具体如下: 学习过小程序的朋友应该知道,在小程序中是不支持cookie的,借助小程序中的缓存我们也可以存储一些信息,但是对于一些比较重要的信息,我们需要通过登录状态维持来保存,同时,为了
本文向大家介绍微信小程序开发(一) 微信登录流程详解,包括了微信小程序开发(一) 微信登录流程详解的使用技巧和注意事项,需要的朋友参考一下 最近在研究微信小程序开发,非常有意思的一个东西。花了一点时间写了一个微信的登录流程,包括后端接口和小程序代码。 做过微信登录的都知道,我们需要一个标识来记录用户的身份的唯一性,在微信中unionId就是我们所需要的记录唯一ID,那么如何拿到unionId就成了
本文向大家介绍微信端开发--登录小程序步骤,包括了微信端开发--登录小程序步骤的使用技巧和注意事项,需要的朋友参考一下 这个小程序的主要目的是为了用户用微信的用户信息登录后将用户信息授权存入自己的数据库中,这样以后每次微信登录得到的code 所得到的 openid 可以在项目的数据库中查到该用户的相关信息。 在测试的过程中,需要用户登录得到的code,所以会用到微信开发小工具~! 该工具的使用必须
uniapp 微信小程序,通过手机号一键登录之后,登录状态过期如何实现静默登录
本文向大家介绍微信小程序 如何获取网络状态,包括了微信小程序 如何获取网络状态的使用技巧和注意事项,需要的朋友参考一下 前言 手机连接到互联网有几种方式:Wifi、2G、3G、4G,包括很快到来的5G,每种方式的上传速度和下载速度差异很大,它们的计费方式的差异也导致用户在使用互联网服务的时候有不同的使用习惯。 Wifi相对于其他几种网络连接方式,其速度会更快。Wifi一般都是免费供用户使用,通过移