}
这是最开始注入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才是王道,避免出现意外的问题