node.js - NodeJs 将文件上传到 AWS S3 - 文件损坏
问题描述
我正在使用 nodejs express 将文件上传到 S3 Bucket。这是我的代码:
HTML 这里我使用 Jquery formData 上传文件
<form id="form" action="" method="post" enctype="multipart/form-data">
<input type="file" name="image" id="image" />
<input class='submit-input' type="submit" value="Submit" />
</form>
<script src="/js/jquery.js"></script>
<script>
$(document).ready(function(e){
$("#form").on('submit', function(e){
e.preventDefault();
$.ajax({
type: 'POST',
url: '/api/upload-image',
data: new FormData(this),
contentType: false,
cache: false,
processData:false,
beforeSend: function(){
$('.submit-input').attr("disabled","disabled");
},
success: function(response){ //console.log(response);
$(".submit-input").removeAttr("disabled");
}
});
});
});
</script>
后端节点
在后端,我使用 multer 来管理文件,并按照 aws-sdk 文档上传到 s3。
var express = require('express');
const router = express.Router();
const AWS = require('aws-sdk');
const fs = require('fs');
//multer
const multer = require('multer')
var storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, '/tmp/')
},
filename: function (req, file, cb) {
cb(null, file.fieldname + '-' + Date.now())
}
})
const upload = multer({ storage: storage })
router.post('/api/upload-image', upload.single('image'), async (req, res) => {
var file = req.file;
AWS.config.update({
accessKeyId: process.env.AWS_PUBLIC,
secretAccessKey: process.env.AWS_SECRET,
region: process.env.AWS_REGION
});
var re = /(?:\.([^.]+))?$/;
var ext = re.exec(file.originalname)[1]
const uniqueKey = 'testDir/'+uuidv4()+'.'+ext;
var buffer = fs.readFileSync(file.path, null)
let params = {
Bucket: process.env.AWS_S3_BUCKET,
Key: uniqueKey,
Body: buffer,
ContentType: file.mimetype
};
let uploadPromise = await new AWS.S3().putObject(params).promise();
return res.status(201).json({});
});
这一切都很好,后端接收文件,我可以在控制台中打印它(并查看名称、mime 类型、大小等)并将文件上传到 s3 存储桶。但是文件不可读(可能已损坏),我看不到这个。不可读文件的大小与原始文件相同。(没有图像文件看起来都是正确的)。
我试图从我的公共目录上传一个文件到 s3,一切正常。所以我认为我的错误是在 jquery 上传和后端检索之间。
解决方案
通过 AWS API Gateway 我需要启用 multipart/form-data。按照本指南解决https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-payload-encodings-configure-with-console.html
推荐阅读
- r - 使用 `mutate(across(where(is.numeric) , some_function))` 代替 `mutate_if(is.numeric, some_function)` 有什么好处吗
- c - 有记忆的奇怪事物
- python - Django:objects.raw() 在使用 Postgresql 时显示错误,但在使用 sqlite3 数据库时工作正常
- docker - 未列出 Docker 容器
- php - PHP 创建 Zip 文件
- powershell - 在控制台上以编程方式更改字体类型和大小
- php - Laravel 媒体存储最佳实践
- numpy - NumPy:如何检查非拥有数组的前导维度?
- python - 如何获取气体量 web3py?
- python - discord bot 脚本在 vps 中不能正常工作?