如果在基于 cookie 的访问限制的站点上使用 AJAX,则 JavaScript 需要访问 cookie。HttpOnly cookie 可以在 AJAX 网站上工作吗?
编辑:如果指定了 HttpOnly,Microsoft 通过禁止 JavaScript 访问 cookie 创建了一种防止 XSS 攻击的方法。FireFox 后来采用了这个。所以我的问题是:如果您在 StackOverflow 之类的网站上使用 AJAX,是否可以选择 Http-Only cookie?
编辑 2:问题 2。如果 HttpOnly 的目的是阻止 JavaScript 访问 cookie,并且您仍然可以通过 JavaScript 通过 XmlHttpRequest 对象检索 cookie,那么 HttpOnly 的意义何在?
编辑3:这是维基百科的引述:
当浏览器接收到这样一个 cookie 时,它应该像往常一样在以下 HTTP 交换中使用它,但不让它对客户端脚本可见。 [32] 该
HttpOnly
标志不是任何标准的一部分,也不是在所有浏览器中都实现。请注意,目前无法阻止通过 XMLHTTPRequest 读取或写入会话 cookie。[33]。
我知道document.cookie
当您使用 HttpOnly 时会被阻止。但似乎您仍然可以读取 XMLHttpRequest 对象中的 cookie 值,从而允许 XSS。HttpOnly 是如何让你变得更安全的呢?通过使cookie基本上只读?
在您的示例中,我无法写入document.cookie
您的 cookie,但我仍然可以窃取您的 cookie 并使用 XMLHttpRequest 对象将其发布到我的域。
<script type="text/javascript">
var req = null;
try { req = new XMLHttpRequest(); } catch(e) {}
if (!req) try { req = new ActiveXObject("Msxml2.XMLHTTP"); } catch(e) {}
if (!req) try { req = new ActiveXObject("Microsoft.XMLHTTP"); } catch(e) {}
req.open('GET', 'http://stackoverflow.com/', false);
req.send(null);
alert(req.getAllResponseHeaders());
</script>
编辑 4:抱歉,我的意思是您可以将 XMLHttpRequest 发送到 StackOverflow 域,然后将 getAllResponseHeaders() 的结果保存到字符串,正则表达式输出 cookie,然后将其发布到外部域。似乎维基百科和黑客在这一点上同意我的观点,但我希望接受再教育......
最终编辑:啊,显然两个站点都是错误的,这实际上是FireFox 中的一个错误。IE6 & 7 实际上是目前唯一完全支持 HttpOnly 的浏览器。
重申我学到的一切:
- HttpOnly 限制对 IE7 & 和 FireFox 中的 document.cookie 的所有访问(不确定其他浏览器)
- HttpOnly 从 IE7 中 XMLHttpObject.getAllResponseHeaders() 的响应标头中删除 cookie 信息。
- XMLHttpObjects 只能提交到它们起源的域,因此不会跨域发布 cookie。
编辑:此信息可能不再是最新的。