问题发生场景 javascript
注册功能, 小程序端第一次调用【发送验证码】接口, 服务器端将验证码存入 session 中。 小程序端第二次调用【注册】接口, 服务器端接收小程序请求的 sessionid, 经过 sessionid 找到 session, 并判断验证码是否是正确java
问题现象小程序
小程序端两次请求的 sessionid 不一致, 致使后端没法取得 session后端
解决办法api
小程序第一次请求, 从服务器端返回的数据中取得 sessionid, 并存到缓存中或全局变量中缓存
wx.request({ url: config.api_url, data: { userPhone: phone }, success: (res) => { if (res && res.header && res.header['Set-Cookie']) { wx.setStorageSync('cookieKey', res.header['Set-Cookie']); //保存Cookie到Storage } } })
小程序第二次请求时, 从缓存中读取 sessionid, 并传递给服务器端服务器
http.request({ url: '/xxx', header: { 'Cookie': wx.getStorageSync('cookieKey') }, data: { userPhone: phone }, success: (data) => { console.log(data) } })
http 为封装的工具类, 主要关注这部分代码cookie
header: { 'Cookie': wx.getStorageSync('cookieKey') }