Вопрос

Я разрабатываю приложение SharePoint 2013 (в Office365), но у меня есть проблемы с доступом в доступе в приложении SharePoint.

Мой код хорошо печатает списки, но он показывает мне только список «Соединенные внешности» и списки «Главная страница галерея», я не могу получить доступ к спискам, которые я создал на моем сайте SharePoint. .

И когда я пытаюсь получить доступ к списку «контактов» (который существует на сайте SharePoint, где я развернул приложение), он получил это исключение:

список "Контакты" не существует на сайте с URL ' https://mysharepointSite-03ea186502297f.sharepoint.com/sphostedApp12

Таким образом, кажется, что мое приложение работает с другого сайта, чем мой главный сайт, и именно поэтому я не могу получить доступ к существующим спискам с моего главного сайта ...

кто-то знает, как решить это и получить доступ к существующим спискам на главном сайте?

Большое спасибо!

Вот мой код app.js:

'use strict';

var gobbe = window.gobbe || {};

gobbe.Contacts;
gobbe.ContactList = function () {
    // private members
    var createItem = function (lname, fname, bphone) {
        var ctx = new SP.ClientContext.get_current();
        var list = ctx.get_web().get_lists().getByTitle('Contacts');
        ctx.load(list);
        var listItemCreationInfo = new SP.ListItemCreationInformation();
        var newContact = list.addItem(listItemCreationInfo);
        newContact.set_item('Last Name', lname);
        newContact.set_item('First Name', fname);
        newContact.set_item('Business Phone', bphone);
        newContact.update();
        ctx.executeQueryAsync(success, error);
    },
    readAll = function () {
        // Not implemented
    },
    readAllSuccess = function () {
        // Not implemented
    },
    updateItem = function () {
        // Not implemented
    },
    updateItem = function (id, lname, fname, bphone) {
        // Not implemented
    },
    removeItem = function (id) {
        // Not implemented
    },
    success = function () {
        readAll();
    },
    error = function (sender, args) {
        alert(args.get_message());
    }

    // public interface
    return {
        createContact: createItem,
        updateContact: updateItem,
        deleteContact: removeItem
    }
}();

gobbe.Collections = function () {
    // private members
    var site,
        listCollection,

        getListCollection = function () {
            var ctx = new SP.ClientContext.get_current();
            site = ctx.get_web();
            ctx.load(site);
            listCollection = site.get_lists();
            ctx.load(listCollection,     'Include(Title,Id,Fields.Include(Title,Description))');
        ctx.executeQueryAsync(success, failure);
        },

        success = function () {
            var html = [];

            // List Information
            html.push('<ul>');
            var listEnumerator = listCollection.getEnumerator();
            while (listEnumerator.moveNext()) {
                // List Title
                html.push('<li>');
                html.push(listEnumerator.get_current().get_title());
                html.push('<ul>');

                // Fields Names
                var fieldEnumerator =     listEnumerator.get_current().get_fields().getEnumerator();
                while (fieldEnumerator.moveNext()) {
                    html.push('<li>');
                    html.push(fieldEnumerator.get_current().get_title());
                    html.push('</li>');
                }

                html.push('</ul></li>')
            }
            html.push('</ul>');

            // Show results
            $('#displayDiv').html(html.join(''));
        },

        failure = function (sender, args) {
            alert(args.get_message());
        }

    // public interface
    return {
        execute: getListCollection
    }
}();

$().ready(function () {
    // Show lists
    gobbe.Collections.execute();

    // Try to add a contact
    gobbe.ContactList.createContact('Cox', 'Brian', '555-555-5555');
    alert('Contact Created!');

    // Update it
    gobbe.ContactList.updateContact(1, 'Cox', 'Brian', '111-111-1111');
    alert('Contact Updated!');

    // Delete it
    gobbe.ContactList.deleteContact(1);
    alert('Contact Deleted!');
});
.

Это было полезно?

Решение

Приложения работают в другом домене по сравнению с вашей сетью Host. Итак, его перекрестный домен, когда вы пытаетесь получить доступ к некоторому списку, который находится в вашем Host Web, из вашего приложения. Обычно браузеры не позволяют сделать эти перекрестные доменные призывы к соображениям безопасности. Однако в приложениях, чтобы взаимодействовать с хост-сетью, есть библиотека под названием SP.REQUESTEXECUTOR.js, которая является либарным поперечным доменом, который вы можете использовать для создания этих вызовов. Пожалуйста, посмотрите на следующие ссылки, которые помогут вам в создании этих пересеченных доменных вызовов для доступа к веб-данным Host внутри приложения.

http://msdn.microsoft.com/en-in/library/ fp179927.aspx

http://www.mavention.com/ Blog / SharePoint-app-app-read-data-from-host-web

http://blogs.msdn.com/b/offiCipps/Archive/2012/11/29/solving-cross-domain-problems-in-apps-for-sharepoint.aspx >

Надеюсь, что помогает.

Другие советы

Похоже, вы забыли дать вашему разрешениям приложения: список «Контакты» не существует на сайте с URL.

Когда вы устанавливаете приложение, вам будет предложено для прав на доступ к конкретной библиотеке или списку.

Вам придется добавить что-то вроде этого ... Пример того, как выглядит разметка в приложении манифеста:

<AppPermissionRequests> <AppPermissionRequest Scope="http://sharepoint/content/sitecollection/web/list" Right="Write"/></AppPermissionRequests>

Чтобы получить доступ к списку из Host Web, вам нужно будет полагаться на «стандартные токены», а затем использовать API EITHE JSOM или REST для доступа к данным.

 //Get the URI decoded URLs.
                hostweburl =
                    decodeURIComponent(
                        getQueryStringParameter("SPHostUrl")
                );
                appweburl =
                    decodeURIComponent(
                        getQueryStringParameter("SPAppWebUrl")
                );
.

Тогда вы можете использовать что-то вроде этого:

 // Initialize the RequestExecutor with the app web URL.
                executor = new SP.RequestExecutor(appweburl);

                // Issue the call against the host web.
                // To get the title using REST we can hit the endpoint:
                //      app_web_url/_api/SP.AppContextSite(@target)/web/title?@target='siteUrl'
                // The response formats the data in the JSON format.
                // The functions successHandler and errorHandler attend the
                //      success and error events respectively.
                executor.executeAsync(
                    {
                        url:
                            appweburl +
                            "/_api/SP.AppContextSite(@target)/web/title?@target='" +
                            hostweburl + "'",
                        method: "GET",
                        headers: { "Accept": "application/json; odata=verbose" },
                        success: successHandler,
                        error: errorHandler
                    }
                );
.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с sharepoint.stackexchange
scroll top