AWS Lambda使用s3 getObject函数和putItem函数将其插入DynamoDB,但没有任何反应

问题描述 投票:0回答:1

这是node.js代码:

'use strict';

const AWS = require("aws-sdk");

AWS.config.update({
    region: 'eu-west-1'});

const docClient = new AWS.DynamoDB.DocumentClient();

const tableName = 'Fair';

const s3 = new AWS.S3();

exports.handler = async (event) => {
    var getParams = {
        Bucket: 'dataforfair', //s3 bucket name
        Key: 'fairData.json' //s3 file location
    }
    
    const data = await s3.getObject(getParams).promise()
    .then( (data) => {
        //parse JSON 
        let fairInformations = JSON.parse(data.Body.toString());

        fairInformations.forEach(function(fairInformationEntry) {
            console.log(fairInformationEntry);
            var params = {
                TableName: tableName,
                Item: {
                    "year": fairInformationEntry.year,
                    "fairName":  fairInformationEntry.fairName,
                    "info": fairInformationEntry.info
                }
            };
        
            docClient.put(params, function(err, data) {
                console.log('*****test');
            if (err) {
                console.error("Unable to add fairInformation", fairInformationEntry.fairName, ". Error JSON:", JSON.stringify(err, null, 2));
            } else {
                console.log("PutItem succeeded:", fairInformationEntry.fairName);
            }
            });
        });
       })
       .catch((err) => {
           console.log(err);
       });
      

    const response = {
        statusCode: 200,
        body: JSON.stringify(data),
    };
    return response;
};

大家好,

我想从s3存储桶获取JSON文件后将数据放入Dynamo DB。获取JSON和console.log(fairInformationEntry);也仍然被触发,但是docClient.put()从未被调用。我没有任何错误,没事。我不知道哪里出了问题,为什么不起作用。我具有正确的IAM角色,可以访问我需要的所有内容。

希望您能帮助我!

node.js amazon-s3 aws-lambda amazon-dynamodb alexa-skills-kit
1个回答
0
投票

问题是promise,callback和async / await的混合。您还试图在foreach中进行异步操作。该代码应如下所示

"use strict";

const AWS = require("aws-sdk");

AWS.config.update({
  region: "eu-west-1"
});

const docClient = new AWS.DynamoDB.DocumentClient();

const tableName = "Fair";

const s3 = new AWS.S3();

exports.handler = async event => {
  var getParams = {
    Bucket: "dataforfair", //s3 bucket name
    Key: "fairData.json" //s3 file location
  };

  const data = await s3.getObject(getParams).promise();
  //parse JSON
  let fairInformations = JSON.parse(data.Body.toString());

  await Promise.all(
    fairInformations.map(fairInformationEntry => {
      console.log(fairInformationEntry);
      var params = {
        TableName: tableName,
        Item: {
          year: fairInformationEntry.year,
          fairName: fairInformationEntry.fairName,
          info: fairInformationEntry.info
        }
      };
      return docClient.put(params).promise();
    })
  );

  const response = {
    statusCode: 200,
    body: JSON.stringify(data)
  };
  return response;
};

希望这会有所帮助

© www.soinside.com 2019 - 2024. All rights reserved.