我试图将图像插入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放入浏览器时图像出现。我错过了什么吗?
答案 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')
希望它会有所帮助!