Я использую файл 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, "<")
.replace(/>/g, ">")
.replace(/"/g, """)
}
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
В чем здесь проблема?
К сожалению, нет, ошибка остается, даже когда я добавляю идентификатор учетной записи в fetchXML.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


куки-файлу пейджинга нужен идентификатор последней записи, включите «accountid» в качестве атрибута в ваш fetchxml
Надеюсь, это поможет - M.Acosta.D
Является ли использование 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, нажмите здесь для получения официальной документации.
ты решил это?