3

好吧,getfile 可用于从 SYSTEM 获取文件,但是如何下载 site.com/t.txt ?

我真的找不到它,而且我发现的东西没有用,如果之前问过请重定向我。

4

2 回答 2

3

在带有 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 之类的库来代替这个。了解更多信息

于 2013-08-04T22:06:11.093 回答
0

只要您不违反同源策略,这很容易。在这种情况下,如果您的脚本嵌入到来自 foo.com 的页面并请求文件 foo.com/* 而不是 subdomain.foo.com/*,则域匹配。

您只需要对文件发出 GET 请求XMLHttpRequest并从响应中读取文件的内容。

如果文件在 foo.com 上但页面不在,您需要在 foo.com 上托管脚本,然后将其包含在此页面中,并带有<script src="foo.com/filerequestscript.js"></script>. (当然,如果你不控制 foo.com,这不太可能发生。)

于 2013-08-04T18:25:56.270 回答