簡體   English   中英

AWS S3 中的“KeyError: 'Records'” - Lambda 觸發器

[英]“KeyError: 'Records'” in AWS S3 - Lambda trigger

我有以下 lambda 函數代碼,用於簡單地打印出 S3 存儲桶上傳事件的作者和元數據:

from __future__ import print_function
import json
import urllib
import boto3

print('Loading function')

s3 = boto3.client('s3')


def lambda_handler(event, context):

    #print("Received event: " + json.dumps(event, indent=2))
    # bucket = event['Records'][0]['s3']['bucket']['name']

    for record in event['Records']:
        bucket = record[0]['s3']['bucket']['name']
        key = record[0]['s3']['object']['key']
        response = s3.head_object(Bucket=bucket, Key=key)

        logger.info('Response: {}'.format(response))

        print("Author : " + response['Metadata']['author'])
        print("Description : " + response['Metadata']['description'])

但是,我在測試時收到以下錯誤:

{
  "stackTrace": [
    [
      "/var/task/lambda_function.py",
      17,
      "lambda_handler",
      "for record in event['Records']:"
    ]
  ],
  "errorType": "KeyError",
  "errorMessage": "'Records'"
}

訪問 S3 對象的存儲桶名稱和密鑰名稱時我做錯了什么嗎? 如果沒有,那么我在這里做錯了什么?

聚會有點晚了。 但這是我的第一篇文章!

解釋:

當您在 lambda 面板中測試時 -> def lambda_handler(event, context) <- 事件被直接注入。

但是在 AWS API 中,它需要添加映射模板或其他 -> event <- 為空,從而導致測驗:

"errorType": "KeyError", "errorMessage": "'Records'"

這是空指針。 記錄不存在,因為 -> 事件 <- 不存在。

解決方案:

您需要在 AWS API 中配置集成請求 單擊“身體映射模板” 然后將映射模板集內容類型添加application/json然后編輯生成的映射模板:

 { "body" : $input.json('$'), "headers": { #foreach($header in $input.params().header.keySet()) "$header": "$util.escapeJavaScript($input.params().header.get($header))" #if($foreach.hasNext),#end #end }, "method": "$context.httpMethod", "params": { #foreach($param in $input.params().path.keySet()) "$param": "$util.escapeJavaScript($input.params().path.get($param))" #if($foreach.hasNext),#end #end }, "query": { #foreach($queryParam in $input.params().querystring.keySet()) "$queryParam": "$util.escapeJavaScript($input.params().querystring.get($queryParam))" #if($foreach.hasNext),#end #end } }

編輯 Lambda 函數

代替:

用於記錄事件['Records']:

和:

用於記錄事件['查詢']['記錄']

不知道堆棧是否會用這個答案告訴你 - 所以我打電話給你@Dawny33 @KevinOelen @franklinsijo

至於解釋,我自己想出來的。 然而“映射模板”來自https://medium.com/simple-thoughts-amplified/passing-variables-from-aws-api-gateway-to-lambda-3c5d8602081b

我昨天遇到了這個問題,問題是當您運行測試時,實際上沒有任何事件 (def lambda_handler(event, context)) 可供 lambda 處理。 事件文檔通常在實際事件發生時生成,這是一個 json 文檔,您的 Python 代碼解析此文檔,然后檢索密鑰。 因此,解決方案是讓您通過在 s3 中刪除文件來創建實際事件,只要您創建了事件通知,那么這將被接收

我也遇到了同樣的問題,我們在這里要做的很簡單。 創建存儲桶/觸發器時的 lambda 區域和區域應該相同。 如果相同,只需將文件上傳到 S3 存儲桶將直接反映到 DynamoDB。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM