来自 lambda 的 AWS s3 上传不起作用且没有错误

nab*_*aba 3 amazon-s3 amazon-web-services aws-lambda

我正在尝试使用 nodejs 将简单的文件从 lambda 上传到 s3。lambda 执行工作正常,没有任何错误,但没有发生 s3 上传。由于没有错误,我无法调试问题。下面是我正在尝试的片段。

var s3 = new AWS.S3();

var params = {
Bucket : "testbucketuploads",
Key : "test.txt",
Body : "Hello!"
}

s3.putObject(params, function(err, data) {
          if (err) console.log(err, err.stack); // an error occurred
          else     console.log(data);           // successful response
});
Run Code Online (Sandbox Code Playgroud)

我已经提供了对 lambda 角色的 S3 访问权限。当我尝试从 CLI 执行相同的操作时,上传工作正常。

小智 7

回答一个旧帖子,但也许它可以帮助某人。我在论坛上寻找解决方案,最终在 aws-sdk 的文档中找到了它。好吧,几个小时的 try&fail 可以为您节省几分钟阅读文档或自述文件的时间。反正。首先,我使用 s3.upload 而不是 s3.putObject。之后,该函数是异步的,如果 lambda 函数在上传之前终止,则不会有任何结果或任何日志。我想出的最漂亮的解决方案是:

const fs = require('fs');
const s3 = new AWS.S3()
const file = fs.readFileSync(someFilePath)
const bucket = "..."
const s3key = "..."
const uploadParams = {
    Bucket: bucket,
    Key: s3key,
    Body: file
};
//executes the upload and waits for it to finish
await s3.upload(uploadParams).promise().then(function(data) {
    console.log(`File uploaded successfully. ${data.Location}`);
}, function (err) {
    console.error("Upload failed", err);
})
//code continues synchronously here
...
return whatEver;
Run Code Online (Sandbox Code Playgroud)

或者,如果您有并希望有一个异步处理程序,您可以返回 Promise 本身。但是,这样做,您将无法控制解析和拒绝回调中发生的事情。即我放置在它们内部的 console.log 没有将日志与处理程序中的其他日志一起写入 lambda 的控制台,这些日志在回调之外(上传之前)被调用。


Ren*_*rro 0

AWS文档表明您需要在参数中发送二进制字符串Body。请查看这篇博客文章如何使用 Javascript 将二进制字符串转换为可读字符串,反之亦然,以及此SO 线程,了解如何为 S3 准备数据的示例。