如您所知,在Internet Explorer下出于安全原因,不允许进行跨域XMLHTTP请求。
我有一个WebBrowser控件,而我正在使用DocumentText
而不是Navigate
来访问网址。由于当页面尝试向自身或其他域发出请求时,当前域为about:blank
,我收到Access is denied
Javascript错误。
即使我使用Navigate
,如果Javascript向另一个域发出请求,它也不起作用。
我怎样才能解决这个问题?
此HTML代码应与WebBrowser Control一起使用:
<body>
<a href="javascript:getit('http://www.google.com')">this should work</a>
<div id="x"></div>
</body>
<script>
function XHConn()
{
var xmlhttp, bComplete = false;
try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); }
catch (e) { try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); }
catch (e) { try { xmlhttp = new XMLHttpRequest(); }
catch (e) { xmlhttp = false; }}}
if (!xmlhttp) return null;
this.connect = function(sURL, sMethod, sVars, fnDone)
{
if (!xmlhttp) return false;
bComplete = false;
sMethod = sMethod.toUpperCase();
try {
if (sMethod == "GET")
{
xmlhttp.open(sMethod, sURL+"?"+sVars, true);
sVars = "";
}
else
{
xmlhttp.open(sMethod, sURL, true);
xmlhttp.setRequestHeader("Method", "POST "+sURL+" HTTP/1.1");
xmlhttp.setRequestHeader("Content-Type",
"application/x-www-form-urlencoded");
}
xmlhttp.onreadystatechange = function(){
if (xmlhttp.readyState == 4 && !bComplete)
{
bComplete = true;
fnDone(xmlhttp);
}};
xmlhttp.send(sVars);
}
catch(z) { return false; }
return true;
};
return this;
}
function getit(url){
var xmlhttp = new XHConn();
var fnWhenDone = function (oXML) { document.getElementById('x').innerHTML = oXML.responseText; alert(oXML.responseText); };
xmlhttp.connect(url, "GET", "", fnWhenDone);
}
</script>
答案 0 :(得分:6)
我找到了一个肮脏的解决方法,加载一个本地HTML(c:\ temp \ temp.html),然后通过javascript修改它的内容。
在此之后不再有CrossDomain限制,但是使用document.write导致其他令人讨厌的问题,例如JQuery .ready
函数将无效。
答案 1 :(得分:1)
检查一下,它对我来说就像一个魅力。 http://support.microsoft.com/default.aspx?scid=kb;en-us;246227
答案 2 :(得分:0)
我不明白您无法访问哪个域的Javascript ... 您是否尝试过使用脚本标记从其他域获取所需的数据?您可以使用JSONP惯用法命名数据...
var head = document.getElementsByTagName("head")[0];
var script = document.createElement("script");
script.src = "anotherdomain.com/data?callback=myFunction";
head.appendChild(script);
然后在“/ data”:
myFunction({
// data here
});
答案 3 :(得分:0)
URLACTION-CROSS-DOMAIN-DATA似乎是正确的方向: Read this to find out why
答案 4 :(得分:0)
执行此操作的唯一方法是确保您的代码在受信任区域(或HTA)中运行。默认情况下,WebBrowser控件内运行的任何内容都在正在提供的文件来自的区域中运行。 (即正在使用标准的IE安全策略。)
要更改此行为,您需要更改承载WebBrowser控件的应用程序,并在该WebBrowser控件上实现一些接口。 (IInternetHostSecurityManager,IInternetZoneManager和IInternetSecurityMgrSite是你应该看看的。)这不是一项微不足道的任务,关于这一点的文档充其量也是稀缺的。
完成此操作后,您的代码可以使用您需要的任何权限运行,跨域请求就像重置Mime-Sweeper高分一样简单。
希望这有帮助。