2017-03-31 95 views
0

我创建了下面的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); 
    } 

}; 
+0

回答是,但它更多的是一个评论:你的lambda函数或你的回调函数需要实际上做的上传,以防止它。而不是让你的lambda函数在上传时触发,也就是在它已经发生之后,你应该在api网关上使用它并调用它,然后如果它通过了你的验证,或者发回你的服务器去做上传,或者让lambda上传本身(我建议) –

+0

如果你的目标是限制上传到S3的大小,那么你可以使用桶政策来做到这一点。请参阅https://aws.amazon.com/articles/1434。 –

回答

1

你不能这样做,如果你的拉姆达由S3通知引发的,仅仅是因为在这种情况下,它不控制文件以任何方式上传。它被简单地称为基于文件上传进行一些处理。如果你想控制文件上传,那么你的上传应该通过lambda功能发生

你目前的情况实际上可以做的是,如果你看到文件大小超过了你所需的限制,你可以删除文件,但你不能阻止文件上传