我是javascript的新手,我正在尝试编写一个将由桶中的PUT事件触发的lambda函数,该函数会将s3对象上的文件名和一些元数据字段写入dynamodb表。我已经完成了大部分工作,但我仍然坚持抓取x-amz-meta标头信息并将变量传递给dynamo.put参数。谁能告诉我我的代码中出错了什么?谢谢!
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 :(得分:2)
看起来你想要这个:
console.log(data.Metadata['x-amz-meta-checksum']);
http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#headObject-property
但是,请注意,您的代码似乎没有正确构建。 s3.headObject
是异步的,因此您的代码会在var params = ...
返回之前继续执行s3.headObject
。下一个动作应该在回调中,或以其他方式处理(瀑布,承诺等),以延迟下一个动作,直到完成。