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