Веб-интерфейс API Dynamics CRM 8.2 «Неправильный XML в файле cookie подкачки»

Я использую файл JavaScript веб-ресурса для получения нескольких записей из CRM.

var fetchXML = `
            <fetch mapping="logical" output-format="xml-platform" version="1.0" page="1">
              <entity name="account" >
                <attribute name="name" />
              </entity>
            </fetch>`;

var query = "accounts?fetchXml=" + fetchXML;

callWebAPI(query);

После того, как я получаю файл cookie подкачки в первом запросе, я пытаюсь отправить его во второй запрос, чтобы получить данные для второй страницы:

<fetch mapping="logical" output-format="xml-platform" version="1.0" page="2" paging-cookie="cookie i get from first request"
     ...
</fetch>`;

Исходный файл cookie из ответа выглядит так:

%253ccookie%2520page%253d%25221%2522%253e%253cname%2520last%253d%2522Deco%2520Voyages%2522%2520firstnull%253d%25221%2522%2520%252f%253e%253caccountid%2520last%253d%2522%257b9AFBEAA6-9EA7-E711-8103-70106FAA4841%257d%2522%2520first%253d%2522%257b0A86656D-BEA7-E711-8103-70106FAA4841%257d%2522%2520%252f%253e%253c%252fcookie%253e

Я попытался преобразовать и отправить cookie согласно документации: https://docs.microsoft.com/en-us/dynamics365/customer-engagement/developer/org-service/page-large-result-sets-with-fetchxml

var transformedCookie1 = GetDecodedCookie1(decodeURIComponent(decodeURIComponent(pagingcookie)));

var transformedCookie2 = GetDecodedCookie2(decodeURIComponent(decodeURIComponent(pagingcookie)));

function GetDecodedCookie1(cookie) {
    return cookie.replace(/</g, "&lt;")
                 .replace(/>/g, "&gt;")
                 .replace(/"/g, "&quot;")
}

function GetDecodedCookie2(cookie) {
    return cookie.replace(/</g, "%26lt;")
                 .replace(/>/g, "%26gt;")
                 .replace(/"/g, "%26quot;")
}

1) В первом случае, когда я использую GetDecodedCookie1, я получаю:

Script error. in  at 0:0  null

введите описание изображения здесь

Мои параметры строки запроса нарушены.

2) Во втором случае, когда я использую параметры строки запроса GetDecodedCookie1, все выглядит нормально, но я получаю:

Malformed XML in the Paging Cookie

В чем проблема?


person Milos    schedule 12.02.2019    source источник
comment
ты решил это?   -  person Marcelo Acosta Díaz    schedule 21.03.2019
comment
К сожалению, нет, ошибка остается, даже когда я добавляю идентификатор учетной записи в fetchXML.   -  person Milos    schedule 21.03.2019


Ответы (2)


для файла cookie подкачки требуется идентификатор последней записи, включая "accountid" в качестве атрибута вашего fetchxml.

Надеюсь, это поможет - М. Акоста.

person Marcelo Acosta Díaz    schedule 22.02.2019

Обязательно ли использование FetchXML для запроса веб-API? В противном случае вы можете упростить себе жизнь с помощью OData. Ваш FetchXML, переведенный в запрос OData, выглядит так:

https://[Organization URI]/api/data/v8.2/accounts?$select=name

Что вернет ответ, аналогичный приведенному ниже, ЕСЛИ в Dynamics будет более 5000 учетных записей, иначе он не будет содержать атрибут @ odata.nextLink (я свернул коллекцию значений для лучшей читаемости):

{
     "@odata.context": "https://[Organization URI]/api/data/v8.2/$metadata#accounts(name)",
     "value": [],
     "@odata.nextLink": "https://[Organization URI]/api/data/v8.2/accounts?$select=name&$skiptoken=%3Ccookie%20pagenumber=%222%22%20pagingcookie=%22%253ccookie%2520page%253d%25221%2522%253e%253caccountid%2520last%253d%2522%257b92655027-054C-E911-A817-000D3ABA3F3F%257d%2522%2520first%253d%2522%257b93C71621-BD9F-E711-8122-000D3A2BA2EA%257d%2522%2520%252f%253e%253c%252fcookie%253e%22%20istracking=%22False%22%20/%3E"
}

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

Для получения дополнительной информации о том, как запрашивать данные с помощью веб-API, щелкните здесь для официальной документации.

person André Cavaca    schedule 21.03.2019