方式一(自定义式)
1.在app.js中定义一个全局变量 cookie: "",名称随意
2.请求接口,比如登录,后台在请求头中获取jsessionId,然后返回给前台。(亦或是json中的某个字段,比如token)
String sessionId=request.getsession().getid()
3.前台在请求的回调中给全局的参数cookie赋值
app.globalData.cookie= 'JSESSIONID=' + res.info
4.然后在请求request的header中添加cookie参数即可
header: { ...., 'cookie': getApp().globalData.cookie },
非常简单粗暴。
方式二(常规方式)
常规方式呢,就是后台把数据放在响应头里,即Response Header,这个里面会有我们需要持久化的信息,即Set-Cookie字段。
当然也可能是在header平级的cookies字段里,视情况而定。
以Set-Cookie为例,其实思想与方式一是一样的,只不过取值方式有点差别而已。
1.取值并存储
if (res.statusCode == 200) { if (res.header['Set-Cookie'] != '') { wx.setStorageSync('Set-Cookie', res.header['Set-Cookie']) } ... }
2.配置请求头
header: { 'content-type': 'application/x-www-form-urlencoded', 'cookie': wx.getStorageSync('Set-Cookie') },
清除cookie
方式一的清除
因为是定义的变量存储,直接把变量值置空就可以了
app.globalData.cookie = ' '
方式二的清除
其实方式二也涉及到存储的知识点了,即有set、get,那也有remove,在需要的地方调用即可
wx.removeStorageSync('Set-Cookie')