1. 程式人生 > >安卓webview注入cookie丟失或者被覆蓋現象探究

安卓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才是王道,避免出現意外的問題偷笑