如何从 CollectionFS 获取文件(图像)的缓冲区
How can I get a buffer for a file (image) from CollectionFS
我正在尝试将图像插入到我正在使用 PDFkit 创建服务器端的 pdf 中。我正在使用 cfs:dropbox 来存储我的文件。在我使用 cvs:filesystem 之前,很容易将图像添加到我的 pdf 中,因为它们就在那里。现在它们是远程存储的,我不确定如何添加它们,因为 PDFkit 不支持仅使用 url 添加图像。但是,它将接受一个缓冲区。如何从我的 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 放入浏览器时图像出现。我错过了什么吗?
我不得不做类似的事情,因为这个问题没有答案,我是这样做的:
// 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')
希望对您有所帮助!
我正在尝试将图像插入到我正在使用 PDFkit 创建服务器端的 pdf 中。我正在使用 cfs:dropbox 来存储我的文件。在我使用 cvs:filesystem 之前,很容易将图像添加到我的 pdf 中,因为它们就在那里。现在它们是远程存储的,我不确定如何添加它们,因为 PDFkit 不支持仅使用 url 添加图像。但是,它将接受一个缓冲区。如何从我的 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 放入浏览器时图像出现。我错过了什么吗?
我不得不做类似的事情,因为这个问题没有答案,我是这样做的:
// 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')
希望对您有所帮助!