所以,我一直在玩NodeJS,我想要做的是接收客户端发送的文件,处理文件(不保存文件,需要逐行处理)然后发送作为文件下载的过程结果。
所以我有以下路线:
app.post('/processFile', function(req, res) {
var file = req.files.file;
//Process file inline
process.processFile(file, req).then((data) => {
//res.setHeader('Content-Length', stat.size);
res.setHeader('Content-Type', 'text/plain');
res.setHeader('Content-Disposition', 'attachment; filename=tokenized.txt');
res.write(data, 'binary');
res.end();
}).catch((err) => {
res.send(err);
});
});
processFile函数如下所示:
processFile: function(file) {
return new Promise(function(resolve, reject) {
var lineReader = require('readline').createInterface({
input: fs.ReadStream(file)
});
var output = "";
lineReader.on('line', function(line) {
// Tokenize each line
DoSomethingFunction(line).then((data) => {
output += data + "\n";
}).catch((err) => {
reject(`Error in line [${line}].`);
});
});
resolve(output);
});
}
当我测试它时,它什么也没做。我只是得到一个空的响应,我做了一些测试并注意到该路由从processFile()promise得到了reject(),但它没有消息。经过一些测试后,我注意到了:
var lineReader = require('readline').createInterface({
input: fs.ReadStream(file)
});
无法正常工作,发送"拒绝"。
任何想法都错了吗?
答案 0 :(得分:0)
问题是lineReader
正在使用异步事件来收集其信息。
基本上,这意味着您在线阅读器处理完任何数据之前正在调用resolve(output)
。相反,您需要侦听另一个事件:the 'close' event。这表示线路阅读器已完成。
lineReader.on('close', () => {
resolve(output);
});
但有一点需要注意。您的DoSomethingFunction
似乎也是异步的。这意味着当'close'事件运行时,它可能等待做一些工作。处理此问题的一种方法是保存DoSomethingFunction
的最新结果并将其附加到“关闭”事件中。
// Initialize to a resolved promise just in case you don't receive
// any data from the user
let doSomethingPromise = Promise.resolve();
lineReader.on('line', (line) => {
doSomethingPromise = DoSomethingFunction(line)
.then((data) => {
output += data + '\n';
})
.catch((err) => {
reject(`Error in line [${line}].`);
});
});
lineReader.on('close', () => {
// Wait for the DoSomethingFunction to finish
doSomethingPromise.then(() => resolve(output));
});