设置cookie是比较常见的配置,cookie持久化以保证免登录、保持会话等等。
方式一(自定义式)
- 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')