我想使用以下库来压缩图像 https://github.com/imagemin/imagemin
问题是当用户使用表单上传时,如何将表单中的文件详细信息插入到图像最小插件中?例如,如果文件表单字段调用 example-image,我如何将该文件表单字段插入 image min 插件,以便它可以压缩图像?
我试过:
req 来自 express/nodejs req
var filebus = new Busboy({ headers: req.headers }),
promises = [];
filebus.on('file', function(fieldname, file, filename, encoding, contentType) {
var fileBuffer = new Buffer(0),
s3ImgPath;
if (file) {
file.on('data', function (d) {
fileBuffer = Buffer.concat([fileBuffer, d]);
}).on('end', function () {
Imagemin.buffer(fileBuffer, {
plugins: [
imageminMozjpeg(),
imageminPngquant({quality: '80'})
]
}).then(function (data) {
console.log(data[0]);
if (s3ImgPath) {
promises.push(this.pushImageToS3(s3ImgPath, data[0].data, contentType));
}
});
}.bind(this));
}
});
但问题是我宁愿有一个可以上传到 S3 的文件缓冲区。我不想将文件放到 build/images 文件夹中。我想为文件获取一个缓冲区,压缩它,然后将该缓冲区上传到 s3。如何使用 image min 通过 html 表单获取文件上传的缓冲区并将其上传到 s3?