2017-08-01 119 views
2

我是JavaScript新手,我正在尝试编写一个lambda函数,该函数会被bucket中的PUT事件触发,函数会将s3对象中的文件名和一些元数据字段写入dynamodb表。我大部分工作已经解决,但我坚持抓住x-amz-meta头信息并将该变量传递给dynamo.put参数。任何人都可以告诉我我的代码中做错了什么?谢谢!s3对象元数据lambda函数

var AWS = require('aws-sdk'); 
var dynamo = new AWS.DynamoDB.DocumentClient({region: 'us-east-1'}); 
var s3 = new AWS.S3(); 
//specify the parameters from event to write to specified db table 
exports.handler = function(event, context, callback) { 
    var srcKey = unescape(event.Records[0].s3.object.key); 
    var srcEtag = unescape(event.Records[0].s3.object.eTag); 
    var scrUploadTime = unescape(event.Records[0].eventTime); 
    var bucket= unescape(event.Records[0].s3.bucket.name); 
    var checksum = 

     s3.headObject(
     { 
      Bucket: bucket, 
      Key: srcKey 
     }, 
     function(err, data) 
     { 
      if (err) 
      { 
       console.log(err); 
       context.done('Error', 'Error getting s3 object: ' + err); 
      } 
      else 
      { 
       return console.log(this.httpResponse.headers['x-amz-meta-checksum']); 
      } 
     }); 

    var params = { 
     Item: { 
      filename: srcKey, 
      uploadtime: scrUploadTime, 
      client_checksum : checksum 
     }, 
     TableName: 'S3_log' 
     }; 

//write to dynammodb 
dynamo.put(params, function(err, data){ 
     if (err) { 
      callback(err, null); 
     }else{ 
      callback(null, data); 
     } 
    }); 
}; 
+0

这是什么“return console.log(this.httpResponse.headers ['x-amz-meta-checksum']);”输出?究竟是什么问题? – Denis

回答

0

它看起来像你想的:

console.log(data.Metadata['x-amz-meta-checksum']); 

http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#headObject-property

而且,请注意,您的代码似乎并没有被正确的结构。 s3.headObject是异步的,因此您的代码在s3.headObject返回之前继续执行var params = ...。接下来的动作可能应该在回调中,或者以另一种方式处理(瀑布,承诺等),以延迟下一个动作,直到完成。