0

例如:<br> 1.Test1.txt 它的base64:VGhpcyBpcyB0ZXN0MS4=
2.Test2.txt 它的base64:VGhpcyBpcyBUZXN0Mi4=

我的代码:

var busboy = new Busboy({ headers: req.headers });
var base64data = [];
busboy.on('file', function(fieldname, file, filename, encoding, mimetype) {
    var output = stream.PassThrough();
    var chunk = [];
    console.log('File: ' + filename + ', mimetype: ' + mimetype);
    file.pipe(base64.encode()).pipe(output);
    output.on('data', function(data) {
        chunk.push(data);
        console.log('Chunk: ' + chunk);
    });
    output.on('end', function(){
        base64data.push(Buffer.concat(chunk));
        console.log('Data1: ' + base64data);
    });
}).on('finish', function(){
    console.log('Data2: ' + base64data);
})

输出:

File: Test1.txt, mimetype: text/plain
File: Test2.txt, mimetype: text/plain
Chunk: VGhpcyBpcyB0ZXN0
Chunk: VGhpcyBpcyBUZXN0
Chunk: VGhpcyBpcyB0ZXN0,MS4=
Chunk: VGhpcyBpcyBUZXN0,Mi4=
Data2:
Data1: VGhpcyBpcyB0ZXN0MS4=
Data1: VGhpcyBpcyB0ZXN0MS4=,VGhpcyBpcyBUZXN0Mi4=

为什么 Data2 为空?如何修改此代码?请帮忙!谢谢~

我尝试在file.event(data)中使用Buffer.toString('base64'),但是只能转换文本内容,图片不能转换?

4

1 回答 1

2

你不需要那些额外的流。但问题是额外的流end事件在下一个滴答声中发出(因此,在 busboy 的finish事件之后)。

您应该能够将代码简化为:

var busboy = new Busboy({ headers: req.headers });
var base64data = [];
busboy.on('file', function(fieldname, file, filename, encoding, mimetype) {
  console.log('File: ' + filename + ', mimetype: ' + mimetype);
  var buffer = '';
  file.setEncoding('base64');
  file.on('data', function(data) {
    // `data` is now a base64-encoded chunk of file data
    buffer += data;
  }).on('end', function() {
    base64data.push(buffer);
  });
}).on('finish', function(){
  console.log('Data2: ' + base64data);
})
于 2015-07-14T05:51:31.113 回答