uniapp 获取请求头set-cookie
时间: 2023-08-12 12:52:55 浏览: 144
在 uniapp 中,可以通过在请求头中设置 `Cookie` 来获取服务器返回的 `Set-Cookie`。具体实现可以参考以下代码示例:
```javascript
uni.request({
url: 'http://example.com/api',
header: {
'Cookie': uni.getStorageSync('cookie') // 从本地缓存中获取 cookie
},
success: (res) => {
if (res.header['Set-Cookie']) {
uni.setStorageSync('cookie', res.header['Set-Cookie']) // 将新的 cookie 存储到本地缓存中
}
console.log(res.data)
},
fail: (err) => {
console.log(err)
}
})
```
在请求成功后,如果服务器返回了 `Set-Cookie`,则可以通过 `res.header['Set-Cookie']` 获取到,然后将其存储到本地缓存中,以便下次请求时使用。需要注意的是,`Set-Cookie` 中可能会包含多个 cookie,需要根据实际情况进行处理。
相关问题
前端获取set-cookie
前端无法直接获取set-cookie,因为set-cookie是在服务器端设置的HTTP响应头。前端可以通过在AJAX请求中设置withCredentials为true来允许跨域请求携带cookie,但是无法直接获取set-cookie的值。一种解决方法是在服务器端将set-cookie的值存储在sessionStorage或localStorage中,然后前端通过读取这些存储的值来获取set-cookie。
uniapp 封装请求 要带上cookie
在 uniapp 中封装请求时,可以在请求头中添加 `Cookie` 字段来携带 cookie。具体实现可以参考以下代码示例:
```javascript
function request(options) {
let cookie = uni.getStorageSync('cookie') // 从本地缓存中获取 cookie
if (cookie) {
options.header = options.header || {}
options.header['Cookie'] = cookie // 将 cookie 添加到请求头中
}
return uni.request(options).then((res) => {
if (res.header['Set-Cookie']) {
uni.setStorageSync('cookie', res.header['Set-Cookie']) // 将新的 cookie 存储到本地缓存中
}
return res.data
})
}
```
在请求函数中,首先从本地缓存中获取 cookie,如果存在则将其添加到请求头中。在请求成功后,如果服务器返回了 `Set-Cookie`,则将其存储到本地缓存中,以便下次请求时使用。这样,在调用封装的请求函数时就会自动携带 cookie。
阅读全文