您的位置:首页 > 理论基础 > 计算机网络

HttpWebRequest跨域cookie的访问

2007-11-21 21:55 585 查看
算算,有一个星期没写blog,自己最近也有些事情忙,而且也没找到很有价值的东西写,所以一直就拉着。最近工作上也没有 特别烦恼的事,所以也就少了些生活感慨。

最近的一个小程序中,使用到HttpWebRequest,在对子域名访问的时候,发现HttpWebRequest并不会提交与他域名不同的cookie值,其实这也是正确,毕竟只需要发送本域cookie就是了,不过HttpWebRequest不会判断是否是主域名的cookie值。比如说

主站 www.ABC.com 有个cookie值为 test : 123123 domain:ABC.com

子站bbs.ABC.com 使用HttpWebRequest访问的时候,就算添加了test这个cookie,它也是不会发送的。

Reflector .net的代码后发现,其添加cookie值的方法如下


if (httpWebRequest.CookieContainer != null)




...{


string str;


httpWebRequest.Headers.RemoveInternal("Cookie");


string cookieHeader = httpWebRequest.CookieContainer.GetCookieHeader(httpWebRequest.Address, out str);


if (cookieHeader.Length > 0)




...{


httpWebRequest.Headers["Cookie"] = cookieHeader;


}


}



这里可以看出,是通过地址得到cookie的值的,所以bbs.ABC.com只会发送domain=bbs.ABC.com的cookie值。

解决方法,强制把domian给改掉就可以了
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐