Я не могу разобрать тело ответа HTTP от Dynamics CRM, оно продолжает возвращаться как символы Юникода - PullRequest
0 голосов
/ 11 июня 2019

Я не могу получить данные в ответ на мой запрос HTTP GET к Dynamics CRM в формате, который доступен для чтения. Он всегда возвращается в виде символов Unicode (т.е. .body: '\ u001f \ b \ u0000 \ u0000 \ u0000 \ u0000 \ u0000 \ u0000 \ m ۸ \ u0011 + Ķ = \ Z \ u0004A7 / \ u000b ... '

Когда я отправляю тот же самый точный GET-запрос в Postman, тело получаемого мной ответа форматируется в удобочитаемом виде и возвращает все необходимые мне знания KnowledgeAr Article - так что (насколько я знаю) HTTP-запрос в порядке (пока токен авторизации остается актуальным).

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

Ниже приведен мой код для парсинга, вызова запроса get и ответа парсинга


const restify = require('restify');
const errors = require('restify-errors');
const port = process.env.PORT || 3000;
const request = require("request");
const stringify = require('stringify');



const server = restify.createServer({
    name: 'restify headstart'
});

server.listen(port, () => {
    console.log(`API is running on port ${port}`);
});

ar options = { method: 'GET',
  url: 'https://########.crm.dynamics.com/api/data/v9.1/knowledgearticles',
  qs: { '$select': 'content,title' },
  headers: 
   { 'cache-control': 'no-cache',
     Connection: 'keep-alive',
     'accept-encoding': 'gzip, deflate',
     cookie: '###################',
     Host: '#####.crm.dynamics.com',
     'Postman-Token': '#######',
     'Cache-Control': 'no-cache',
     'User-Agent': 'PostmanRuntime/7.13.0',
     Authorization: 'Bearer ################# buncha crap #####',
     Accept: 'application/json'
    } 
};

request(options, function (error, response, body) {
  if (error) throw new Error(error);

  // below are all of my attempts at parsing 'response'

  * let aaa = response;
  * let aaa = response.toJSON();
  * let aaa = JSON.stringify(response);
  * let aaa = response.toString();
  * let aaa = response.toJSON(body);

  * let aaa = response.setEncoding('binary');
  * let aaa = aaaa.toJSON();

  // none of the above result in my response logging into readable text

  console.log(aaa);
});

Ответы [ 2 ]

1 голос
/ 17 июня 2019

Вы сжали response, удалите 'accept-encoding': 'gzip, deflate' header

const options = {
    method: "GET",
    url: "https://contactcenter.crm.dynamics.com/api/data/v9.1/knowledgearticles",
    qs: {"$select": "content,title"},
    headers: {
        "cache-control": "no-cache",
        "connection": "keep-alive",
        "cookie": "...",
        "host": "contactcenter.crm.dynamics.com",
        "postman-token": "...",
        "User-Agent": "PostmanRuntime/7.13.0",
        "authorization": "Bearer ...",
        "accept": "application/json"
    }
}

или добавить gzip: true для запроса параметров

const options = {
    method: "GET",
    url: "https://contactcenter.crm.dynamics.com/api/data/v9.1/knowledgearticles",
    qs: {"$select": "content,title"},
    headers: {
        "cache-control": "no-cache",
        "connection": "keep-alive",
        "accept-encoding": "gzip, deflate",
        "cookie": "...",
        "host": "contactcenter.crm.dynamics.com",
        "postman-token": "...",
        "User-Agent": "PostmanRuntime/7.13.0",
        "authorization": "Bearer ...",
        "accept": "application/json"
    },
    gzip: true
};

или распакуйте вручную response

0 голосов
/ 11 июня 2019

Я считаю, что вы ищете JSON.parse().

Вот полный пример, созданный CRMRESTBuilder Джейсона Латтимера .

var req = new XMLHttpRequest();
req.open("GET", Xrm.Page.context.getClientUrl() + "/api/data/v9.1/knowledgearticles?$select=content,title", true);
req.setRequestHeader("OData-MaxVersion", "4.0");
req.setRequestHeader("OData-Version", "4.0");
req.setRequestHeader("Accept", "application/json");
req.setRequestHeader("Content-Type", "application/json; charset=utf-8");
req.setRequestHeader("Prefer", "odata.include-annotations=\"*\"");
req.onreadystatechange = function() {
    if (this.readyState === 4) {
        req.onreadystatechange = null;
        if (this.status === 200) {
            var results = JSON.parse(this.response);
            for (var i = 0; i < results.value.length; i++) {
                var content = results.value[i]["content"];
                var title = results.value[i]["title"];
            }
        } else {
            Xrm.Utility.alertDialog(this.statusText);
        }
    }
};
req.send();
...