我正在将jpg文件流式传输到节点服务器。但是问题有时它会起作用,有时它会因为下面的错误而崩溃并导致我的服务器崩溃
events.js:183
066466+00:00 app[web.1]: throw er; // Unhandled 'error' event
2018-06-19T00:45:07.066468+00:00 app[web.1]: ^
2018-06-19T00:45:07.066470+00:00 app[web.1]:
066472+00:00 app[web.1]: Error: Unexpected end of multipart data
2018-06-19T00:45:07.066474+00:00 app[web.1]: at
/app/node_modules/busboy/node_modules/dicer/lib/Dicer.js:62:28
这是我处理文件的代码
req.busboy.on('file', function (fieldname, file, filename) {
console.log("Uploading: " + (filename));
fstream = fs.createWriteStream(__dirname + '/public/img/'+ filename);
file.on('data', function(chunk) {
fstream.write(chunk);
});
file.on('end', function() {
fstream.end();
console.log('File [' + fieldname + '] Finished sucessfully');
});
file.on('error',function(err){
console.log('fstream error' + err);
file.unpipe();
});
});
有人可以帮助解决这里的问题吗? 提前谢谢。
答案 0 :(得分:0)
好,回答我自己的问题。我没有正确处理错误事件。这是工作代码。
var fstream;
req.pipe(req.busboy);
req.busboy.on('file', function (fieldname, file, filename) {
console.log("Uploading: " + (filename));
fstream = fs.createWriteStream(__dirname + '/public/img/'+ filename);
file.on('data', function(chunk) {
fstream.write(chunk);
});
file.on('error',function(err){
console.log('fstream error ' + err);
});
file.on('end', function() {
fstream.end();
console.log('File [' + fieldname + '] Finished sucessfully');
});
});
req.busboy.on('error',function(err){
console.log('req.busboy error' + err);
});