okHttp管理cookie的简单方法

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

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

有一个简单粗暴的方法:

  1. 通过某种方式获取到后端发送的Cookie的名称和值。
    由于是前后端是通过接口调用方式交换数据,后端可以在用户登录之后把Cookie的名字和值作为业务数据返回给前端。
    Java Servlet 可以用session.getId()获取Cookie的值,至于Cookie的名称,可以通过网页调试工具获取。

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

  3. 统一在请求中加上一个名字为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();
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值