您的位置:首页 > 理论基础 > 计算机网络

okHttp管理cookie的简单方法

2017-08-24 20:46 176 查看
初识okHttp,发现默认不管理
cookie
,登录成功之后,后端设置了
cookie
,但是由于okHttp在后面的请求没有携带
cookie
,导致被后端认为没有登录而不能正常获取数据。

百度了一下,发现别人的方法有点复杂。

有一个简单粗暴的方法:

通过某种方式获取到后端发送的Cookie的名称和值。

由于是前后端是通过接口调用方式交换数据,后端可以在用户登录之后把Cookie的名字和值作为业务数据返回给前端。

Java Servlet 可以用
session.getId()
获取Cookie的值,至于Cookie的名称,可以通过网页调试工具获取。

在app端保存服务端返回的cookie的值。在app生命周期内可以用一个全局变量保存这个cookie的值。

统一在请求中加上一个名字为
Cookie
的HTTP报头,
Cookie
报头的形式如下:

Cookie:COOKIE_NAME=COOKIE_VALUE


假设有如下代码:

Request request = new Request
.Builder()
.url(url)
.build();


后端发送的
Set-Cookie
中设置的
cookie
的名字为
JSESSEONID


于是只需加上一行代码,即可解决:

Request request = new Request
.Builder()
.url(url)
.addHeader("Cookie", "JSESSIONID=" + cookieValue)
.build();
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: