首页 > 代码库 > Android的cookie的接收和发送
Android的cookie的接收和发送
我在做自动登录的时候遇到的坑,特写此文以提醒各位不要把自己绕进去了。
我们都知道在web端的cookie是可以通过服务器端设置保存的,默认是关闭浏览器就清除cookie的,但是可以在服务器端设置cookie的有效期,浏览器就会自动保存cookie,而在Android上是不会自动保存cookie,我用的是Okhttp3,我找不到response.addCookie(cookie)和request.getCookies()的方法(Java web的操作),如果没有保存和重发cookie给服务器的话,是不会自动登录的。搞了大半天才知道这一切都在head里。
如果是Okhttp3的话是这样的
在日志输出的cookie
通过这样的方法我们已经拿到了cookie,接下来就是保存cookie了,写以下的静态方法来将cookie保存到SharedPreferces,我的设计思想是尽量少操作数据库。
1 public static final String ISLOGINED = "islogined"; 2 public static final String COOKIE = "cookie"; 3 4 5 public static void saveCookiePreference(Context context, String value) { 6 SharedPreferences preference = context.getSharedPreferences(ISLOGINED, Context.MODE_PRIVATE); 7 SharedPreferences.Editor editor = preference.edit(); 8 editor.putString(COOKIE, value); 9 editor.apply(); 10 11 }
然后调用该方法保存cookie
然后再写一个方法来在SharedPreferces获取cookie的值
public static String getCookiePreference(Context context) { SharedPreferences preference = context.getSharedPreferences(ISLOGINED, Context.MODE_PRIVATE); String s = preference.getString(COOKIE, ""); return s; }
最后要做的是在每次的请求时带上cookie,这cookie是放在head里。
这样就可以实现自动登录了。
Android的cookie的接收和发送
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。