节点服务器文件处理抛出多部分数据的意外结束

时间:2018-06-19 01:23:31

标签: node.js multer busboy

我正在将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();
    });
   });

有人可以帮助解决这里的问题吗? 提前谢谢。

1 个答案:

答案 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);

  });