1

这是我在 Stackoverflow 上的第一篇文章。希望你们能帮我解决我的问题。我在 domain1.sharepoint.com 上有一个 HTML 页面,我正在尝试使用 JQuery+SPServices 从 domain2.sharepoint.com 上的 SharePoint 获取全部列表项。

我知道由于同源策略,我需要使用 XMLHttpRequest (CORS) 来获取我需要的数据。不幸的是,我不确定如何将 XMLHttpRequest 放入 SPServices。我已经尝试过,并收到“未定义”错误。我对 JavaScript 很陌生,感谢所有帮助。

这是我到目前为止所做的:

$.support.cors = true;
function createCORSRequest(method, refURL) {
  var xhr = new XMLHttpRequest();
  if ("withCredentials" in xhr) {
    xhr.open(method, refURL, true);
  } else if (typeof XDomainRequest != "undefined") {
    xhr = new XDomainRequest();
    xhr.open(method, refURL);
  } else {
    xhr = null;
  }
  return xhr;
}

function makeCorsRequest() {
  var refURL = 'http://domain1.sharepoint.com';
  var spURL = refURL;

  var xhr = createCORSRequest('GET', spURL);
  if (!xhr) {
    alert('CORS not supported');
    return;
  }
  xhr.onload = function() {
    $().SPServices({
        operation: "GetListItems",
        webURL: spURL,
        listName: "Message Log",
        viewName: "{70DFBF9A-5266-4D69-AD01-E848301B51BB}",
        async: false,
        CAMLViewFields: "<ViewFields><FieldRef Name='Status' /></ViewFields>",
        completefunc: function (xData, status) {
            $("#countlist").html($(xData.responseXML).find("z\\:row").length);
        }
    });
};

  xhr.onerror = function(e, jqxhr) {
    alert('Woops, there was an error making the request. ' + jqxhr);
  };

  xhr.send();
}

onload = makeCorsRequest;
4

1 回答 1

1

我觉得你做的太多了。这一行:

$.support.cors = 真;

应该是启用跨域所需的唯一东西。这告诉 jQuery 启用 cors 并由它负责其余的工作。

一旦设置好,就可以正常调用 SPServices 并确保将“webURL”选项设置为指向 domain2。

请注意,虽然这将在“现代”浏览器中工作,但 IE(我认为)会提示用户获得许可。

于 2013-10-02T22:15:19.730 回答