回答
致电android.webkit.CookieManager
的getCookie
方法为您感兴趣的URL或域生成RFC 2109 Cookie
标头。解析cookie标题以获取cookie名称列表。对于每个cookie名称,为该名称生成一个RFC 2109 Set-Cookie
标题,该标题的过期日期已过期,并将其传递到CookieManager
的setCookie
方法中。尽管API文档指定setCookie
忽略已过期的值,但在这种情况下,Android的当前实现实际上会刷新cookie。为防止未来的实现忽略文档中指定的过期值,请检查cookie是否真的被删除,并执行一些后备行为,如果它们没有 - CookieManager
的removeAllCookie
方法可能对此回退有用。
我在API中并没有看到这样做,但你总是可以深入到真正的源代码中(例如,我发现这个类的deleteCookies
方法:WebViewDatabase其中是Android核心的一部分。
正如你可以看到那里...... Cookie只是SQLite数据库中的行...所以如果你能使这个类工作,至少你知道如何通过你自己做到这一点。
我知道这是有点老了,但我正在寻找这个自己。如果我自己修改webview.db数据库,是否有可能发生冲突?如果CookieSyncManager或WebView在修改它时访问它,是否存在线程安全和锁定问题? – cottonBallPaws 2011-04-07 17:57:38
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();
}
这是来自开源项目的代码示例。也许可以帮助某人。
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();
}
}
- 1. 如何从使用Javascript的特定域中删除cookie?
- 2. Android WebView从特定域中删除Cookie
- 3. 如何使用jQuery从Cookie中删除特定的Cookie
- 4. 如何删除无Cookie域的Cookie
- 5. 如何删除特定的cookie值?
- 6. 如何使用PHP或JavaScript删除特定的Cookie前缀?
- 7. 如何使用JavaScript删除特定网站的Cookie?
- 8. 如何设置/删除跨域cookie?
- 9. 从CookieManager中有选择地删除cookie android
- 10. 未使用CookieManager的Android会话Cookie
- 11. 问题删除指定域的Cookie
- 12. 如何从CookieManager android获取所有cookie?
- 13. 如何删除cookie的cookie?
- 14. 从其他域删除cookie
- 15. 删除Rails 3子域Cookie
- 16. 如何获取特定cookie的域名?
- 17. 删除特定名称的Cookie
- 18. JS + PHP - 删除特定的Cookie
- 19. 从cookie中删除特定值
- 20. 如何删除cookie
- 21. 如何清除iOS中特定域的Cookie?
- 22. 如何使用硒删除Google Chrome Cookie?
- 23. 如何使用javascript删除cookie
- 24. 如何使用Javascript删除cookie?
- 25. 如何删除所有Cookie使用jQuery
- 26. 为PHPCrawl中的特定域设置Cookie
- 27. PHP的cookie,只为特定子域
- 28. 如何使用硒将cookie添加到特定域
- 29. 如何使用javascript修改特定域的现有cookie值?
- 30. 如何使用硒添加cookie哪个特定域名.CreatCookie
在android中有没有可以帮助我们的cookie解析器?或者我们应该只是做split()和我们自己? – Enigma 2012-08-31 05:34:17
@Enigma阅读RFC,它描述了cookie字符串的确切格式。 – rpetrich 2012-09-04 01:16:23
谢谢:)它的工作原理:) – Enigma 2012-09-04 06:59:26