2010-05-14 52 views

回答

9

致电android.webkit.CookieManagergetCookie方法为您感兴趣的URL或域生成RFC 2109 Cookie标头。解析cookie标题以获取cookie名称列表。对于每个cookie名称,为该名称生成一个RFC 2109 Set-Cookie标题,该标题的过期日期已过期,并将其传递到CookieManagersetCookie方法中。尽管API文档指定setCookie忽略已过期的值,但在这种情况下,Android的当前实现实际上会刷新cookie。为防止未来的实现忽略文档中指定的过期值,请检查cookie是否真的被删除,并执行一些后备行为,如果它们没有 - CookieManagerremoveAllCookie方法可能对此回退有用。

+0

在android中有没有可以帮助我们的cookie解析器?或者我们应该只是做split()和我们自己? – Enigma 2012-08-31 05:34:17

+0

@Enigma阅读RFC,它描述了cookie字符串的确切格式。 – rpetrich 2012-09-04 01:16:23

+0

谢谢:)它的工作原理:) – Enigma 2012-09-04 06:59:26

1

我在API中并没有看到这样做,但你总是可以深入到真正的源代码中(例如,我发现这个类的deleteCookies方法:WebViewDatabase其中是Android核心的一部分。

正如你可以看到那里...... Cookie只是SQLite数据库中的行...所以如果你能使这个类工作,至少你知道如何通过你自己做到这一点。

+0

我知道这是有点老了,但我正在寻找这个自己。如果我自己修改webview.db数据库,是否有可能发生冲突?如果CookieSyncManager或WebView在修改它时访问它,是否存在线程安全和锁定问题? – cottonBallPaws 2011-04-07 17:57:38

11
public void clearCookies(String domain) { 
    CookieSyncManager.createInstance(this); 
    CookieManager cookieManager = CookieManager.getInstance(); 
    String cookiestring = cookieManager.getCookie(domain); 
    String[] cookies = cookiestring.split(";"); 
    for (int i=0; i<cookies.length; i++) { 
     String[] cookieparts = cookies[i].split("="); 
     cookieManager.setCookie(domain, cookieparts[0].trim()+"=; Expires=Wed, 31 Dec 2025 23:59:59 GMT"); 
    } 
    CookieSyncManager.getInstance().sync(); 
} 
+0

“过期”部分答案拯救了我的一天。谢谢。 – trante 2014-08-08 21:47:53

+3

从我做过的研究看来,您需要在调用setCookie()时提供域和路径。单独传递域名对我来说不起作用,而且我无法找到获取给定域的Cookie路径的方法 - 只是名称和值。 – markproxy 2014-11-11 23:15:19

+0

在示例代码中,为什么未来会过期? – 2016-04-28 02:24:59

3

这是来自开源项目的代码示例。也许可以帮助某人。

https://github.com/janrain/engage.android/blob/96f21b45738ef82a911e27d8a707aff3a1024d36/Jump/src/com/janrain/android/utils/WebViewUtils.java

private static void deleteWebViewCookiesForDomain(Context context, String domain, boolean secure) { 
    CookieSyncManager csm = CookieSyncManager.createInstance(context); 
    CookieManager cm = CookieManager.getInstance(); 

    /* http://code.google.com/p/android/issues/detail?id=19294 */ 
    if (AndroidUtils.SDK_INT >= 11) { 
     // don't trim leading '.'s 
    } else { 
     /* Trim leading '.'s */ 
     if (domain.startsWith(".")) domain = domain.substring(1); 
    } 

    /* Cookies are stored by domain, and are not different for different schemes (i.e. http vs 
    * https) (although they do have an optional 'secure' flag.) */ 
    domain = "http" + (secure ? "s" : "") + "://" + domain; 
    String cookieGlob = cm.getCookie(domain); 
    if (cookieGlob != null) { 
     String[] cookies = cookieGlob.split(";"); 
     for (String cookieTuple : cookies) { 
      String[] cookieParts = cookieTuple.split("="); 

      /* setCookie has changed a lot between different versions of Android with respect to 
      * how it handles cookies like these, which are set in order to clear an existing 
      * cookie. This way of invoking it seems to work on all versions. */ 
      cm.setCookie(domain, cookieParts[0] + "=;"); 

      /* These calls have worked for some subset of the the set of all versions of 
      * Android: 
      * cm.setCookie(domain, cookieParts[0] + "="); 
      * cm.setCookie(domain, cookieParts[0]); */ 
     } 
     csm.sync(); 
    } 
} 
+0

它是如何工作的? – Robert 2015-05-13 08:31:02

+0

就我而言,我只需要确保域名是正确的(以“。”开头),它会将所有cookie值重置为空字符串。效果很好。 – Meng 2015-05-13 08:47:38

+0

我觉得这个功能有问题。在我为“twitter.com”和“api.twitter.com”执行后,Twitter不再加载(Android模拟器6.0上的空白页面)。但是,它适用于Facebook。 – 2017-07-24 12:19:46