我有一个使用CORS并设置cookie的GWT应用程序。它在Chrome, Firefox, Opera中工作正常,但在IE10(版本10.0.9200.16521)我得到这个错误:
SCRIPT5022: com.google.gwt.core.client.JavaScriptException: (InvalidStateError)
code: 11
ABORT_ERR: 20
DATA_CLONE_ERR: 25
DOMSTRING_SIZE_ERR: 2
HIERARCHY_REQUEST_ERR: 3
INDEX_SIZE_ERR: 1
INUSE_ATTRIBUTE_ERR: 10
INVALID_ACCESS_ERR: 15
INVALID_CHARACTER_ERR: 5
INVALID_MODIFICATION_ERR: 13
INVALID_NODE_TYPE_ERR: 24
INVALID_STATE_ERR: 11
NAMESPACE_ERR: 14
NETWORK_ERR: 19
NOT_FOUND_ERR: 8
NOT_SUPPORTED_ERR: 9
NO_DATA_ALLOWED_ERR: 6
NO_MODIFICATION_ALLOWED_ERR: 7
PARSE_ERR: 81
QUOTA_EXCEEDED_ERR: 22
SECURITY_ERR: 18
SERIALIZE_ERR: 82
SYNTAX_ERR: 12
TIMEOUT_ERR: 23
TYPE_MISMATCH_ERR: 17
URL_MISMATCH_ERR: 21
VALIDATION_ERR: 16
WRONG_DOCUMENT_ERR: 4: InvalidStateError
B3D7C8F35C000AA1ADFE700845710C1A.cache.html, line 1102 character 7
我看到当执行这个命令时抛出了错误:
xhr.withCredentials = true;
以下是GWT javascript代码:
function create_3(){
var xhr;
if ($wnd.XMLHttpRequest) {
xhr = new $wnd.XMLHttpRequest;
}
else {
try {
xhr = new $wnd.ActiveXObject('MSXML2.XMLHTTP.3.0');
}
catch (e) {
xhr = new $wnd.ActiveXObject('Microsoft.XMLHTTP');
}
}
xhr.withCredentials = true;
return xhr;
}
我发现了这个帖子:在IE9中使用cookie进行CORS请求?
然而,我升级到IE10,并没有什么不同。
还有人遇到类似的问题吗?
我有一个类似的问题(一般使用CORS,而不是专门使用GWT)。原来是浏览器设置屏蔽了第三方cookie (IE10> Internet选项>隐私>高级>第三方cookie>接受)。为了解决这个问题,我选择了"覆盖自动cookie处理","接受"(第三方cookie)和"始终允许会话cookie"。
要求用户重新配置浏览器以允许所有第三方cookie是不太可能成功的。正确的解决方法是确保目标第三方资源具有一个P3P策略,该策略对于在第三方上下文中使用的资源是可以接受的。http://blogs.msdn.com/b/ieinternals/archive/2013/09/17/simple-introduction-to-p3p-cookie-blocking-frame.aspx