安卓webview注入cookie丢失或者被覆盖现象探究

   private void setWebViewCookie() {
        CookieSyncManager.createInstance(this);
        CookieManager cookieManager = CookieManager.getInstance();
        cookieManager.acceptCookie();
        String cookie = new SharePreferenceUtil(this).getCookie();
        if (!cookie.equals(""))
            cookieManager.setCookie(UrlUtil.H5_HOST, cookie);
         CookieSyncManager.getInstance().sync();

    }


这是最开始注入cookie的形式,一般来说没有问题,但是我用webview访问了微信的某个站点,微信给我返回了JessionId信息

结果以后再发送请求的时候,仅仅使用新的sessionId,老的sessionId浏览器没有使用,从而不能正常访问我自己的网站了


原因分析:首先得具备cookie作用域的知识,请点击http://blog.csdn.net/kky2010_110/article/details/4743796

                  还要了解cookieManager.setCookie的用法 请点击http://www.360doc.com/content/14/0903/22/9200790_406874810.shtml

           1.  setCookie的第一个参数是访问的URL,如果URL的主域名不正确,那么cookie就会用不上了大笑

        2.所有cookie的属性要在第二个参数中设置,例如:;Domain=."+UrlUtil.H5_HOST+";Path=/");

  
我的cookie之所以被微信的sessionId覆盖了,是因为的和微信的sessionIdDomain都没有设置(默认应该是所有吧),Path也都是"/"

那么这种情况下,实际上确实是只会使用后面的一个了,请看下面的测试案例

   private void setWebViewCookie() {
        CookieSyncManager.createInstance(this);
        CookieManager cookieManager = CookieManager.getInstance();
        cookieManager.acceptCookie();
        String cookie = new SharePreferenceUtil(this).getCookie();
        if (!cookie.equals(""))
          A: cookieManager.setCookie(UrlUtil.H5_HOST, cookie+";Domain=."+UrlUtil.H5_HOST+";Path=/");
         B:cookieManager.setCookie(UrlUtil.H5_URL, cookie+"123"+";Domain=."+UrlUtil.H5_HOST+";Path=/");
        CookieSyncManager.getInstance().sync();
    }

A 和B设置的cookie作用域都是一样的,PATH也是一样的,结果只使用了B的Cookie

而如果B的Domain的作用域修改成一个完全不一样的Domain,A就不会被覆盖掉了


总结:合理的设置Cookie的Domain和Path才是王道,避免出现意外的问题偷笑



你可能感兴趣的:(安卓webview注入cookie丢失或者被覆盖现象探究)