1

我想使用以下库来压缩图像 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?

4

1 回答 1

4

输出参数的文档显示它是可选的(尽管不可否认,函数声明没有,这可能会造成混淆)。

输出

类型:字符串

将目标文件夹设置为您的文件将被写入的位置。如果未指定目标,则不会写入任何文件。

因此,您可以选择不将文件写入存储,而只使用内存中的输出:

imagemin([file.path], {
  plugins: [
      imageminMozjpeg(),
      imageminPngquant({quality: '65-80'})
  ]
}).then(files => {
  // upload file to S3
});
于 2016-10-26T16:00:48.463 回答