如何从CollectionFS获取文件(图像)的缓冲区

时间:2015-06-23 00:03:29

标签: javascript node.js meteor node-pdfkit collectionfs

我试图将图像插入pdf我正在使用PDFkit创建服务器端。我使用cfs:dropbox来存储我的文件。在我使用cvs:filesystem之前,很容易将图像添加到我的pdf中,因为它们就在那里。现在他们已远程存储,我不知道如何添加它们,因为PDFkit不支持仅使用网址添加图像。但是,它会接受一个缓冲区。如何从我的CollectionFS文件中获取缓冲区?

到目前为止,我有这样的事情:

var portrait = Portraits.findOne('vS2yFy4gxXdjTtz5d');
readStream = portrait.createReadStream('portraits');

到目前为止,我尝试了两种缓冲方式:

首先使用dataMan,但最后一个命令永远不会回来:

var dataMan = new DataMan.ReadStream(readStream, portrait.type());
var buffer = Meteor.wrapAsync(Function.prototype.bind(dataMan.getBuffer, dataMan))();

第二次手动缓冲流:

var buffer = new Buffer(0);
readStream.on('readable', function() {
    buffer = Buffer.concat([buffer, readStream.read()]);
});
readStream.on('end', function() {
    console.log(buffer.toString('base64'));
});

这似乎永远不会回来。我仔细检查了我的文档以确保它在那里并且它有一个有效的URL并且当我将URL放入浏览器时图像出现。我错过了什么吗?

1 个答案:

答案 0 :(得分:5)

我必须做类似的事情,因为这个问题没有答案,我就是这样做的:

// take a cfs file and return a base64 string
var getBase64Data = function(file, callback) {
  // callback has the form function (err, res) {}
  var readStream = file.createReadStream();
  var buffer = [];
  readStream.on('data', function(chunk) {
    buffer.push(chunk);
  });
  readStream.on('error', function(err) {
    callback(err, null);
  });
  readStream.on('end', function() {
    callback(null, buffer.concat()[0].toString('base64'));
  });
};

// wrap it to make it sync    
var getBase64DataSync = Meteor.wrapAsync(getBase64Data);

// get a cfs file
var file = Files.findOne();

// get the base64 string
var base64str = getBase64DataSync(file);

// get the buffer from the string
var buffer = new Buffer(base64str, 'base64')

希望它会有所帮助!