好吧,getfile 可用于从 SYSTEM 获取文件,但是如何下载 site.com/t.txt ?
我真的找不到它,而且我发现的东西没有用,如果之前问过请重定向我。
在带有 XMLHTTPRequest 的现代浏览器中,您的要求非常简单。例如:
function load(url, callback) {
var xhr = new XMLHTTPRequest();
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) callback(xhr.responseText);
};
xhr.open("GET", url, true);
}
load("site.com/t.txt", function (contents) {
// contents is now set to the contents of "site.com/t.txt"
});
但是为了确保浏览器与 Internet Explorer 完全兼容,需要更多代码,因为 Internet Explorer 使用 ActiveXObject 而不是 XMLHTTPRequest。
function createXHR() {
if (typeof XMLHTTPRequest === "undefined") {
if (createXHR._version) return new ActiveXobject(createXHR._version);
else {
var versions = [
"Micrsoft.XMLHTTP",
"Msxml2.XMLHTTP",
"Msxml2.XMLHTTP",
"Msxml2.XMLHTTP.3.0",
"Msxml2.XMLHTTP.4.0",
"Msxml2.XMLHTTP.5.0",
"Msxml2.XMLHTTP.6.0"
];
var i = versions.length;
while (--i) try {
var v = versions[i], xhr = new ActiveXObject(v);
createXHR._version = v;
return xhr;
} catch {}
}
} else return new XMLHTTPRequest();
}
function load(url, callback) {
var xhr = createXHR();
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) callback(xhr.responseText);
};
xhr.open("GET", url, true);
}
我真的建议使用 jQuery 之类的库来代替这个。了解更多信息
只要您不违反同源策略,这很容易。在这种情况下,如果您的脚本嵌入到来自 foo.com 的页面并请求文件 foo.com/* 而不是 subdomain.foo.com/*,则域匹配。
您只需要对文件发出 GET 请求XMLHttpRequest
并从响应中读取文件的内容。
如果文件在 foo.com 上但页面不在,您需要在 foo.com 上托管脚本,然后将其包含在此页面中,并带有<script src="foo.com/filerequestscript.js"></script>
. (当然,如果你不控制 foo.com,这不太可能发生。)