1

我正在将许多图像存储在AWS S3中。如何从s3存储和检索dynamodb中的照片网址?

我需要从S3中检索URL并将其存储在DynamoDB中。

我不清楚如何通过NodeJS来做到这一点。有人可以解释它如何与Lambda函数一起工作吗?

+0

的方法之一https://snowulf.com/2015/08/05/tutorial-aws -api-gateway-to-lambda-to-dynamodb/ – BMW

+0

是的。研究人员,在论坛上提问之前阅读文档! – iSkore

+0

对于一个问题,您必须发布您已经采取的步骤,您尝试过的代码以及您遇到的错误。 – iSkore

回答

0

您需要创建一个将由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控制台中上传文件,然后瞧瞧。

问候

+0

不是特别详细,但是。这是初学者用户,需要完整的步骤 – iSkore

3
  1. 一定有你的S3存储所有的设置与任何你需要的。不知道为什么你想要这个,但我会假设你已经设置为私人或公共。
    • 如果你有静态主机启用,网址在这会很
  2. 导航到Lambda和设置您的功能。投入名称,说明等,但没有在代码字段(我们将到达那里)
  3. 设置您的RAM和权限
  4. (必须至少有基本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)); 
    
        }); 
    
    }; 
    

实施例:icon - 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" 
         } 
        ] 
    } 
    
  • 现在运行测试,你应该看到你的数据库中的记录 - 如果没有,继续编辑您的数据库参数,直到您得到它们正确

    • 请确保您为分配给此Lambda函数的角色设置了所有权限
  • 一旦它的工作原理,转到Event sources标签的顶部和选择+ Add event source =>Event source type =>S3
  • 一个请求S3样的信息应该出现菜单。把你想要的水桶,前缀,后缀,不管是谁 - 然后选择Event type =>Object Created,要么(All)或上市