2013-07-12 2 views
5

Я создаю прототипы приложения, используя собственный 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" 
+1

Я попытался бы прочитать заголовки и запросить тело в узле и попросить его трассировать/распечатать, что происходит в обоих случаях. Это попытка понять, что представляет собой информация о запросе или способ появления запросов, а затем искать конкретные ответы на пути устранения различий между вашим запросом на завивание и запросом ajax (настройка заголовков в угловом и т. Д.) – shaunhusain

+0

@ shaunhusain, я проверил заголовки, и они те же, поэтому я также проверил весь объект 'req' (с FileMerge), и он возвращает _0 difference_ – jacob

+1

ну, что жуткий :) извините, я не знаю, что вам сказать , если данные, отправленные на машину, точно совпадают, и он реагирует двумя разными способами, я понятия не имею, что происходит. Возможно, мы разозлили богов узлов или угловых богов (возможно, одного из богов OSI более низкого уровня), и мы должны покаяться. Как вы собираете данные? Я использовал Чарльза с большим успехом в прошлом (вы уверены, что это происходит?) – shaunhusain

ответ

10

узла http.request() возвращает данные в chunks для потоковой передачи (было бы неплохо, если бы они явно указали это). Таким образом, необходимо записать каждый фрагмент в тело ответа Express, listen for the end of the http request (что действительно не задокументировано), а затем позвонить response.end(), чтобы закончить ответ.

var req = http.request(options, function(res) 
    { 
    res.on('data', function(chunk) { response.write(chunk); }); 
    res.on('end', function() { response.end(); }); 
    } 
); 
req.on('error', function(error) { … }); 
req.end(); 

Где response является ответ Экспресса по запросу первоначального клиента (скрученный или АЯКС вызова углового-х).

+1

Я думаю, это просто спасло мою жизнь вместе с [AngularUI typeahead conflict with $ resource] (http://stackoverflow.com/questions/15930339/how-to-tie-angular-uis-typeahead -with-a-server-through-http-for-server-side-optimi) –

+1

Фактически вы можете использовать pipe() для упрощенной реализации. Там крошечный пакет npm, который будет обрабатывать котлы (я думаю, что это называется Request). – jacob

+0

@jacod любая ссылка на npm для этого, это то, что я получаю [npmjs] (https://www.npmjs.com/package/pipe) –

Смежные вопросы