как обработать/проанализировать/прочитать ответ "multipart / mixed; boundary=batch
Как обработать/проанализировать / прочитать ответ типа "multipart / mixed; boundary=batch" с помощью JavaScript / jQuery?
в нашем приложении мы получим ответ, как показано ниже:
есть ли способ обработать такие ответы? Или мы должны использовать необработанные строковые манипуляции с использованием regex и т. д., Чтобы получить контент, который мы хотим?
--batchresponse_e3e3tc10-1181-4b94-bb8a-952452769d53
Content-Type: multipart/mixed; boundary=changesetresponse_4sdflwerf-40ef-4347-8c77-b364e5d2e678
--changesetresponse_4sdflwerf-40ef-4347-8c77-b364e5d2e678
Content-Type: application/http
Content-Transfer-Encoding: binary
HTTP/1.1 201 Created
DataServiceVersion: 1.0;
Content-Type: application/json;odata=verbose;charset=utf-8
Content-ID: 1
X-Content-Type-Options: nosniff
Cache-Control: no-cache
Location: <url1>
{"Some": "JSON response"}
--changesetresponse_4sdflwerf-40ef-4347-8c77-b364e5d2e678
Content-Type: application/http
Content-Transfer-Encoding: binary
HTTP/1.1 204 No Content
Content-ID: 2
X-Content-Type-Options: nosniff
Cache-Control: no-cache
DataServiceVersion: 1.0;
--changesetresponse_4sdflwerf-40ef-4347-8c77-b364e5d2e678
Content-Type: application/http
Content-Transfer-Encoding: binary
HTTP/1.1 204 No Content
Content-ID: 3
X-Content-Type-Options: nosniff
Cache-Control: no-cache
DataServiceVersion: 1.0;
--changesetresponse_4sdflwerf-40ef-4347-8c77-b364e5d2e678--
--batchresponse_e3e3tc10-1181-4b94-bb8a-952452769d53--
2 ответов
к сожалению, там, кажется, нет библиотеки, чтобы справиться с этим. Вот что я в итоге сделал. Следующее решение предполагает, что доступны angular и lodash ( " _ " ), но его можно адаптировать к другим фреймворкам.
учитывая, что responseCollection
- это http-ответ, показанный в начальном сообщении, сначала мы находим границу из начального заголовка. Затем используйте эту границу, чтобы разделить ответ на его составляющие. В каждом компоненте, предполагается, что первый экземпляр "{
" отмечает начало JSON и последний экземпляр "}
" Это конец. JSON десериализуется и помещается в коллекцию объектов ответа.
это, очевидно, не будет работать для каждого сценария и делает некоторые общие предположения, но этого было достаточно, чтобы решить мою проблему.
function parseBatch(responseCollection) {
var items = [];
var boundary = getBatchSeparator(responseCollection);
var responseLines = responseCollection.data.split('--' + boundary);
_.forEach(responseLines, function (response) {
var startJson = response.indexOf('{');
var endJson = response.lastIndexOf('}');
if (startJson < 0 || endJson < 0) {
return;
}
var responseJson = response.substr(startJson, (endJson - startJson) + 1);
var item = angular.fromJson(responseJson);
items.push(item);
});
return items;
}
function getBatchSeparator(response) {
var headers = response.headers();
if (!headers['content-type'])
return ''; //would probably be bad if this happens, but not sure it ever will.
var components = headers['content-type'].split(';');
var boundary = _.find(components, function (o) { return _.startsWith(_.trim(o), 'boundary=') });
boundary = _.replace(boundary, 'boundary=', '');
boundary = _.trim(boundary, '; ');
return boundary;
}
var boundary= '--batch_';
var items = [];
var responseLines = batchapiresponse.split(boundary);
$.each(responseLines,function(index, value){
var startJson = value.indexOf('{');
var endJson = value.lastIndexOf('}');
if (startJson < 0 || endJson < 0)
{
return;
}
var responseJson = value.substr(startJson, (endJson - startJson) + 1);
responseJson=JSON.parse(responseJson);
items.push(responseJson);
});
Примечание: это получено из предыдущего образца кода из @SouthShoreAK для jQuery.
его написано в предположении, что каждый пакетный ответ содержит '--batch_' в качестве подстроки в границе. P. S в основном написано для пакетных запросов Google