Щомісячні архіви: Січень 2015

HTTP 406 Помилка при використанні кутових $http.get проти SharePoint відпочинку кінцевих точок

Оновлення: Марк оголошення ndersson вказав на цей великий шматок інформація: http://Blogs.Office.com/2014/08/13/JSON-Light-support-Rest-SharePoint-API-Released/. Це багато що пояснює :).

Що може бути коли-небудь найгірших заголовок повідомлення в блозі! Anyhoo.

Я зазвичай робити всі мої Прототипування проти O365 екземпляр. У мене є моє особисте екземпляр так що я не повинні бути турбуюся про зачіпають будь-хто інший. Як у бік – пам'ятаєте, коли ми закликаємо рознесену навколо віртуальних машин наші ноутбуки з МОСС-SQL Server, IIS, Вирішивши проти Hyper-V. VMWare? Anyhoo...

Я розробив програму за допомогою кутових в цьому середовищі, що робить, серед іншого, Це:

$HTTP.Get(serverUrl)
.успіх(функція(дані, статус, заголовки, Config) {

VAR getLinksResponse = даних;

getLinksResponse.value.forEach(функція(theResult) {

// і так далі і так піни

Це працює лише штрафом у двох різних середовищах онлайн SharePoint. Однак, Коли, мій колега портовано на Cloudshare екземпляр, він отримував послугами HTTP 406 помилка (яка була в перший раз я коли-небудь отримав що один, так.. Яй, Я гадаю). Ми зробили кілька досліджень і зауважив, що заголовку «Прийняти» був відключений. SharePoint онлайн була абсолютно щаслива зі:

Прийняти: застосування/json

Але cloudshare екземпляр (яка містить SP прем, відбулася у віртуальному сервері) хотів класичний "odata = verbose" додані також:

Прийняти: застосування/json;odata = verbose

Щоб виправити, що, Ми додали заголовка таким чином:

VAR config = {заголовки: {
"Приймати": ' застосування/json;odata = verbose'
}
};

$HTTP.Get(serverUrl,Config)
.успіх(функція(дані, статус, заголовки, Config) {

VAR getLinksResponse = даних;

getLinksResponse.value.forEach(функція(theResult) {

// і так далі і так піни

Що позбулися на 406, але це також змінив формат відповідь. Це було більше.. verbose. (Ха-ха!) Більше змін були необхідні і ось кінцевий результат:

VAR config = {заголовки: {
"Приймати": ' застосування/json;odata = verbose'
}
};

$HTTP.Get(serverUrl,Config)
.успіх(функція(дані, статус, заголовки, Config) {

VAR getLinksResponse = даних;

getLinksResponse.d.results.forEach(функція(theResult) {

// і так далі і так піни

Це тільки перетворився на 30 хвилина проблема для нас, так ми пощастило. Ми сподіваємося хтось вважає, що це корисна.

</кінець>

Як-к: Увімкнути кілька кутових SharePoint веб-частини на одній сторінці

Цей блог посад описує, як ви можете мати кілька Angular.js на основі веб-частини SharePoint (посилання за допомогою веб-частини редактора вмісту) на одній сторінці. Я дзвоню контент-редактор веб-частини (CEWP) який посилається JavaScript, побудований з використанням Angular.js рамках послугами "Кутовий веб-частини."

Bootstrap процес кутової, це просто супер, і майже кожен приклад, ви знайдете на Інтернет йде щось на зразок цього:

<HTML ng-app = 'myApp'>

<бла /><бла /><бла />

</HTML>

Це виходить з ладу, Однак, Щоб увімкнути кілька CEWP, що представляють кілька кутових веб-частин на одній сторінці. Кутовий буде тільки автоматично завантаженні проти першої директиви ng-app знахідки – щонайменше починаючи з кутовою версії 1.3.6. Рішення досить проста – вручну завантаженні вашого коду замість. Вище тепер змін щось на зразок цього:

<тіло>
<d
IV id =”bootstrapHere” NG контролер =”myController як theController”>
<бла /><бла /><бла />
</DIV>
</тіло>

<скрипт src =”//Ajax.googleapis.com/AJAX/libs/angularjs/1.3.6/angular.js”></сценарій>

<сценарій>
angular.Bootstrap(angular.Element(document.getElementById(“bootstrapHere”)),['myApp']);
</сценарій>

В основному, Замість того щоб використовувати ng-app на елемент робити ваші початкова завантаження, ви вдарите ID на цей елемент. Потім, використовувати початкового завантаження() метод на кутових сам контролювати, що початкова завантаження процесу під час роботи. Я це перевіряв це три різні кутові веб-частин на тій же сторінці, і вона працює Шарм.

</кінець>

undefinedПідписатися на мій блог.

Йди за мною на Twitter в http://www.twitter.com/pagalvin