Я создаю прототипы приложения, используя собственный mongo rest api, где Node возвращает около 400 тыс. Json. Я использую следующее Maket он обращается к родному API Монго и возвращают результат:NodeJS/ExpressJS посылает ответ большого количества данных в 1 потоке
http.request(options, function(req)
{
req.on('data', function(data)
{
console.log(data,data.rows);
response.send(200, data);
}
);
}
)
.on('error', function(error)
{
console.log('error\t',error);
response.send(500, error);
}
)
.end();
Когда я ударил http://localhost:8001/api/testdata
через завиток, ответ правильный (как то, что выводится на консоль узла с console.log
и тем, что получил с помощью завитка). Но когда я ударил его через ajax в моем приложении, поток ... перегружен, даже data
, выведенный на консоль узла (Terminal), нечетный: он имеет несколько EOF, а ответ Network для вызова в инструментах разработчика chrome заканчивается на первом EOF.
Еще одна странная вещь: data
выглядит следующим образом:
{
"offset": 0,
"rows": [ … ]
}
, но ни в одном узле, ни на стороне клиента (угловой) можно ссылаться data.rows (она возвращает неопределенное значение). typeof data
[object Object]
.
РЕДАКТИРОВАТЬ заголовков запроса для оба локона и углового (по данным Node) являются:
req.headers: {
'x-action': '',
'x-ns': 'test.headends',
'content-type': 'text/plain;charset=utf-8',
connection: 'close',
'content-length': '419585'
}
РЕДАКТИРОВАТЬ Я проверил заголовки ответа в обеих угловых и скручиваться непосредственно (а не от узла), annnd есть разногласие (такой же вывод, как и угловой ротор напрямую, а не от узла):
access-control-allow-headers: "Origin, X-Requested-With, Content-Type, Accept"
access-control-allow-methods: "OPTIONS,GET,POST,PUT,DELETE"
access-control-allow-origin: "*"
connection: "keep-alive"
content-length: "65401" // <---------------- too small!
content-type: "application/octet-stream"
// ^-- if i force "application/json"
// with response.json() instead of response.send() in Node,
// the client displays octets (and it takes 8s instead of 0s)
date: "Mon, 15 Jul 2013 18:36:50 GMT"
etag: ""-207110537""
x-powered-by: "Express"
Я попытался бы прочитать заголовки и запросить тело в узле и попросить его трассировать/распечатать, что происходит в обоих случаях. Это попытка понять, что представляет собой информация о запросе или способ появления запросов, а затем искать конкретные ответы на пути устранения различий между вашим запросом на завивание и запросом ajax (настройка заголовков в угловом и т. Д.) – shaunhusain
@ shaunhusain, я проверил заголовки, и они те же, поэтому я также проверил весь объект 'req' (с FileMerge), и он возвращает _0 difference_ – jacob
ну, что жуткий :) извините, я не знаю, что вам сказать , если данные, отправленные на машину, точно совпадают, и он реагирует двумя разными способами, я понятия не имею, что происходит. Возможно, мы разозлили богов узлов или угловых богов (возможно, одного из богов OSI более низкого уровня), и мы должны покаяться. Как вы собираете данные? Я использовал Чарльза с большим успехом в прошлом (вы уверены, что это происходит?) – shaunhusain