aws lambda拒绝文件上传
问题描述:
我创建了下面的aws lambda函数,并为我的目标存储桶上的所有S3上传事件设置触发器。该函数尝试拒绝大于2000000字节的文件上载。错误消息已记录,但context.fail('上传被拒绝')或context.fail(新错误('上传被拒绝'))均未阻止失败上传。如何拒绝文件上传,或者一般情况下,拒绝/停止aws lambda的事件?aws lambda拒绝文件上传
//// AWS的NodeJS代码拉姆达://///
exports.handler = (event, context, callback) => {
var MAX_FILE_SIZE = 2000000;
var msg = '';
console.log('Received event:', JSON.stringify(event, null, 2));
if (event.Records && event.Records.length && event.Records.length>0 && event.Records[0].s3 && event.Records[0].s3.object
&& event.Records[0].s3.object.size && event.Records[0].s3.object.size > MAX_FILE_SIZE) {
msg = 'File ' + event.Records[0].s3.object.key + ' rejected, file size ' + event.Records[0].s3.object.size
+ ' is greater than ' + MAX_FILE_SIZE + ' bytes.';
console.log(msg);
var err = new Error(msg);
callback(err, {'disposition':'STOP_RULE'});
context.fail(err);
} else {
msg = 'Upload succeeded.';
console.log(msg);
callback(null, msg);
context.succeed(msg);
}
};
答
你不能这样做,如果你的拉姆达由S3通知引发的,仅仅是因为在这种情况下,它不控制文件以任何方式上传。它被简单地称为基于文件上传进行一些处理。如果你想控制文件上传,那么你的上传应该通过lambda功能发生
你目前的情况实际上可以做的是,如果你看到文件大小超过了你所需的限制,你可以删除文件,但你不能阻止文件上传
回答是,但它更多的是一个评论:你的lambda函数或你的回调函数需要实际上做的上传,以防止它。而不是让你的lambda函数在上传时触发,也就是在它已经发生之后,你应该在api网关上使用它并调用它,然后如果它通过了你的验证,或者发回你的服务器去做上传,或者让lambda上传本身(我建议) –
如果你的目标是限制上传到S3的大小,那么你可以使用桶政策来做到这一点。请参阅https://aws.amazon.com/articles/1434。 –