前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android的cookie的接收和发送

Android的cookie的接收和发送

作者头像
夜雨飘零
修改2023-06-04 16:28:30
9230
修改2023-06-04 16:28:30
举报
文章被收录于专栏:CSDN博客CSDN博客

我在做自动登录的时候遇到的坑,特写此文以提醒各位不要把自己绕进去了。

我们都知道在web端的cookie是可以通过服务器端设置保存的,默认是关闭浏览器就清除cookie的,但是可以在服务器端设置cookie的有效期,浏览器就会自动保存cookie,而在Android上是不会自动保存cookie,我用的是Okhttp3,我找不到response.addCookie(cookie)和request.getCookies()的方法(Java web的操作),如果没有保存和重发cookie给服务器的话,是不会自动登录的。搞了大半天才知道这一切都在head里。

如果是Okhttp3的话是这样的

在日志输出的cookie

通过这样的方法我们已经拿到了cookie,接下来就是保存cookie了,写以下的静态方法来将cookie保存到SharedPreferces,我的设计思想是尽量少操作数据库。

代码语言:javascript
复制
public static final String ISLOGINED = "islogined";
public static final String COOKIE = "cookie";
  
 public static void saveCookiePreference(Context context, String value) {
    SharedPreferences preference = context.getSharedPreferences(ISLOGINED, Context.MODE_PRIVATE);
     SharedPreferences.Editor editor = preference.edit();
     editor.putString(COOKIE, value);
     editor.apply();
}

然后调用该方法保存cookie

然后再写一个方法来在SharedPreferces获取cookie的值

代码语言:javascript
复制
public static String getCookiePreference(Context context) {
    SharedPreferences preference = context.getSharedPreferences(ISLOGINED, Context.MODE_PRIVATE);
    String s = preference.getString(COOKIE, "");
    return s;
}

最后要做的是在每次的请求时带上cookie,这cookie是放在head里。

这样就可以实现自动登录了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-05-13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
作者已关闭评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档