我正在将许多图像存储在AWS S3中。如何从s3存储和检索dynamodb中的照片网址?
我需要从S3中检索URL并将其存储在DynamoDB中。
我不清楚如何通过NodeJS来做到这一点。有人可以解释它如何与Lambda函数一起工作吗?
我正在将许多图像存储在AWS S3中。如何从s3存储和检索dynamodb中的照片网址?
我需要从S3中检索URL并将其存储在DynamoDB中。
我不清楚如何通过NodeJS来做到这一点。有人可以解释它如何与Lambda函数一起工作吗?
您需要创建一个将由S3 put event调用的Lambda函数。 Lambda函数抓取了具有event
细节的JSON(和相应的var
。问题是对象的URL不会出现在JSON中,但是您可以使用JSON参数来构建url,url将如下所示:
https://s3-region.amazonaws.com/bucket/key
还可以再插入此网址到DynamoDB与AWSSDK for NodeJS,URL格式将在弗吉尼亚州(美国标准)的区域不同。总之,HERE你有联系以获取更多信息。
,创建在S3控制台中的存储桶中或直接在Lambda控制台中上传文件,然后瞧瞧。
个问候
不是特别详细,但是。这是初学者用户,需要完整的步骤 – iSkore
(必须至少有基本DynamoDB执行权限)现在它会负载用于第二,当其完成 - 糊在此代码
const
AWS = require('aws-sdk');
AWS.config.region = 'us-east-1';
exports.handler = function(event, context) {
var ddb = new AWS.DynamoDB(),
bucket = event.Records[ 0 ].s3.bucket.name,
key = event.Records[ 0 ].s3.object.key,
params = {
TableName: '[table]',
Item: {
hash: '[hash]',
range: '[range]',
s3key: 'https://s3.amazonaws.com/' + bucket + '/' + key
}
};
console.log('\n\n{\n Bucket: ' + bucket + ',\n Key: ' + key + ',\n URL: ' + params.Item.s3key + '\n}\n');
ddb.put(params, function(err, data) {
// respond with whatever you want
context.succeed((err) ? JSON.stringify(err, null, 2) : JSON.stringify(data, null, 2));
});
};
实施例: - https://s3.amazonaws.com/cerenity/SOResources/favicon.ico
更新:@agl提醒我,如果你不使用“美国标准”区域,指定区域将是:https://s3-[here].amazonaws.com/
转到Actions
=>Configure test event
=>Sample event template
=>S3 Put
,你应该看到:
{
"Records": [
{
"eventVersion": "2.0",
"eventTime": "1970-01-01T00:00:00.000Z",
"requestParameters": {
"sourceIPAddress": "127.0.0.1"
},
"s3": {
"configurationId": "testConfigRule",
"object": {
"eTag": "abcdefabcdef",
"sequencer": "0A1B2C3D4E5F678901",
"key": "HappyFace.jpg",
"size": 1024
},
"bucket": {
"arn": "arn:aws:s3:::mybucket",
"name": "sourcebucket",
"ownerIdentity": {
"principalId": "EXAMPLE"
}
},
"s3SchemaVersion": "1.0"
},
"responseElements": {
"x-amz-id-2": "EXAMPLE123/5678abcdefghijklambdaisawesome/mnopqrstuvwxyzABCDEFGH",
"x-amz-request-id": "EXAMPLE123456789"
},
"awsRegion": "us-east-1",
"eventName": "ObjectCreated:Put",
"userIdentity": {
"principalId": "EXAMPLE"
},
"eventSource": "aws:s3"
}
]
}
现在运行测试,你应该看到你的数据库中的记录 - 如果没有,继续编辑您的数据库参数,直到您得到它们正确
Event sources
标签的顶部和选择+ Add event source
=>Event source type
=>S3
Event type
=>Object Created
,要么(All)
或上市
的方法之一https://snowulf.com/2015/08/05/tutorial-aws -api-gateway-to-lambda-to-dynamodb/ – BMW
是的。研究人员,在论坛上提问之前阅读文档! – iSkore
对于一个问题,您必须发布您已经采取的步骤,您尝试过的代码以及您遇到的错误。 – iSkore