我遇到了一些代码,这些代码使用以下类型的referrer hack通过IE中的Javascript将referrer信息传递到弹出窗口:
var targetName = "linkTarget";
_win = window.open("", targetName, 'width=800,height=480,resizable=yes,status=yes,location=yes,toolbar=no');
var _link;
if (!document.getElementById("referrerHackLink")) {
_link = document.createElement('a');
_link.id = "referrerHackLink";
document.body.appendChild(_link);
}
else {
_link = document.getElementById("referrerHackLink");
}
_link.target = targetName;
_link.href = url;
_link.click();
http://webbugtrack.blogspot.com/2008/11/bug-421-ie-fails-to-pass-http-referer.html
有趣的是,当我尝试对某些 URI(包括 localhost)使用该方法时,IE9 和 IE10 会模糊弹出窗口并导航到主窗口中的目标 URL。
你可以在这里找到一个例子:http: //jsfiddle.net/geoffreymoller/JKXzk/
关于为什么 localhost 版本可能会更改弹出窗口和目标信息的任何想法?