NodeJs Грозный сценарий блокировки формы поста
Я использую nodejs и грозный, чтобы показать индикатор выполнения файла из почтовой формы.
var formidable = require('formidable'),
http = require('http'),
util = require('util');
http.createServer(function(req, res) {
if (req.url == '/test.html' && req.method.toLowerCase() == 'post') {
console.log("FILE UPLOAD")
// parse a file upload
var form = new formidable.IncomingForm();
form.parse(req, function(err, fields, files) {
res.writeHead(200, {'content-type': 'text/plain'});
res.write('received upload:\n\n');
res.end(util.inspect({fields: fields, files: files}));
});
form.on('progress', function(bytesReceived, bytesExpected) {
console.log(bytesReceived+" / "+bytesExpected);
});
return;
}
// show a file upload form
res.writeHead(200, {'content-type': 'text/html'});
res.end(
'<form action="/test.html" enctype="multipart/form-data" method="post">'+
'<input type="text" name="title"><br>'+
'<input type="file" name="upload" multiple="multiple"><br>'+
'<input type="submit" value="Upload">'+
'</form>'
);
}).listen(8050);
В локальной сети все в порядке, байт журнала консоли получен и ожидается во время отправки файла. Но на моем сервере консольный журнал блокируется до завершения загрузки файла... Даже для 'console.log("ЗАГРУЗКА ФАЙЛА") появляется только после завершения файла... Так что я не могу отследить событие прогресса...
Возможно, это поведение сервера для настройки, я нахожусь на 7 ОС Linux. Спасибо за помощь.