Jør*_*Vik 5 javascript amazon-s3 node.js multer multer-s3
如果我要上传图像,除了创建缩略图之外,我还希望 multer s3 保留原始图像。
换句话说。我只想在第一次转换中更改文件名。
下面的代码可以正常工作,但问题是sharp() 修改了原始代码。假设我上传了一个 gif 文件,动画将停止工作。
我试图从原始转换对象中删除转换箭头函数,但这会导致代码崩溃,错误为dest.on is not a function。
我已经尝试删除整个转换对象,但由于 shouldTransform 是真实的,它根本不会上传原件。
我试图取代sharp()用null,但是这给了我这个错误不能“开”读取属性无效的。
根据文档,我应该能够在sharp() 位置输入一个字符串,但这也会使代码崩溃。示例:cb(null, "something.jpeg");
错误:dest.on 不是函数
关于 multer-s3-transform 的文档有点缺乏,所以我现在只是在暴力破解。
const awsStorage = multerS3({
s3,
bucket: process.env.AWS_BUCKET_NAME,
shouldTransform: (transformReq, file, cb) => {
cb(null, /^image/i.test(file.mimetype));
},
key: (transformReq, file, cb) => {
const splitFileName = file.originalname.split('.');
const fileEnding = splitFileName[splitFileName.length - 1];
cb(null, `files/${dateNow}.${fileEnding}`);
},
transforms: [
{
id: 'original',
key: (transformReq, file, cb) => {
const splitFileName = file.originalname.split('.');
const fileEnding = splitFileName[splitFileName.length - 1];
cb(null, `files/${dateNow}.${fileEnding}`);
},
transform: (transformReq, file, cb) => {
cb(null, sharp()); // This is where I'm struggling
},
},
{
id: 'thumbnail',
key: (transformReq, file, cb) => {
const splitFileName = file.originalname.split('.');
const fileEnding = splitFileName[splitFileName.length - 1];
cb(null, `thumbnails/${dateNow}.${fileEnding}`);
},
transform: (transformReq, file, cb) => {
cb(
null,
sharp()
.resize(200, 200)
.png()
);
},
},
],
});
Run Code Online (Sandbox Code Playgroud)
您可以从第一个变换对象(原始)中删除变换块吗?
transform: (transformReq, file, cb) => {
cb(null, sharp()); // This is where I'm struggling
}
Run Code Online (Sandbox Code Playgroud)
如果您只是想重命名该文件,那么关键部分应该足够了。您在下面的缩略图上正确使用了锐利。
| 归档时间: |
|
| 查看次数: |
404 次 |
| 最近记录: |