Получить listitem, используя jquery или javascript из Office 365 (Sharepoint Online)? - PullRequest
0 голосов
/ 06 марта 2012

есть хорошие решения для получения данных из офиса 365 и перемещения их на другую платформу с использованием объектной модели клиента. То есть Wictor Wilen решение. его работа в коде позади.

Я попытался получить список данных из офиса 365 на другую платформу, например, проект Azure (HTML-страница). Я пытался использовать .asmx веб-сервисов. это прекрасно работает на странице сайта Office 365. но когда скрипт переходит на любую другую HTML-страницу (проект Azure). он не работает. Я прошел учетные данные, даже если они не работают. Вот мой сценарий.

 function GetData()
 {

    var soapEnv =
        "<soapenv:Envelope xmlns:soapenv='http://schemas.xmlsoap.org/soap/envelope/'><soapenv:Body><GetListItems xmlns='http://schemas.microsoft.com/sharepoint/soap/'><listName>Cloud</listName><query><Query></Query></query> \
                     <viewFields> \
                        <ViewFields> \
                           <FieldRef Name='OfficeCountry' /> \
                           <FieldRef Name='Title' /> \
                       </ViewFields> \
                    </viewFields> \
                </GetListItems> \
            </soapenv:Body> \
        </soapenv:Envelope>";

    $.ajax({
        url: "https://nexpo.sharepoint.com/_vti_bin/lists.asmx",
        type: "POST",
        dataType: "xml",
        data: soapEnv,
        processData: false,
       beforeSend : function(req) {
         req.setRequestHeader('Authorization', 
               make_base_auth ('username', 'pwd'));
    },
        complete: processResult,
        contentType: "text/xml; charset=\"utf-8\""
    });
  }
 function processResult(xData, status) {

    $(xData.responseXML).find("z\\:row").each(function() {

       var lititle=  $(this).attr("ows_Title");            
       alert(lititle);

    });
  }

 function make_base_auth(user, password) {
   var tok = user + ':' + password;
   var hash = Base64.encode(tok);
   return "Basic " + hash;
 }

это может быть причиной междоменной проблемы. но возможно ли это сделать таким образом? У кого-нибудь есть лучшее решение или идея для извлечения данных?

1 Ответ

1 голос
/ 06 марта 2012

Посмотрите в этом блоге, как данные списка SharePoint читаются с использованием модели клиентских объектов и JQuery, а не веб-служб.

http://blogs.msdn.com/b/steve_fox/archive/2011/10/05/using-windows-azure-to-connect-lob-data-to-sharepoint-online-using-business-connectivity-services.aspx

...