热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何使用控制台在awsSNS中发送json消息正文

我正在尝试将SNS触发器添加到lambda函数的位置,然后该函数将消息发送到松弛通道。这个lambda在python中有一个蓝图,还有一个模板测试事件,如下所示

我正在尝试将 SNS 触发器添加到 lambda 函数的位置,然后该函数将消息发送到松弛通道。这个 lambda 在 python 中有一个蓝图,还有一个模板测试事件,如下所示

{
"Records": [
{
"EventVersion": "1.0",
"EventSubscriptionArn": "arn:aws:sns:EXAMPLE",
"EventSource": "aws:sns",
"Sns": {
"SignatureVersion": "1",
"Timestamp": "1970-01-01T00:00:00.000Z",
"Signature": "EXAMPLE",
"SigningCertUrl": "EXAMPLE",
"MessageId": "12345",
"Message": {
"AlarmName": "SlackAlarm",
"NewStateValue": "OK",
"NewStateReason": "Threshold Crossed: 1 datapoint (0.0) was not greater than or equal to the threshold (1.0)."
},
"MessageAttributes": {
"Test": {
"Type": "String",
"Value": "TestString"
},
"TestBinary": {
"Type": "Binary",
"Value": "TestBinary"
}
},
"Type": "Notification",
"UnsubscribeUrl": "EXAMPLE",
"TopicArn": "arn:aws:sns:EXAMPLE",
"Subject": "TestInvoke"
}
}
]

蓝图中的 lambda 处理程序中的代码如下

import boto3
import json
import logging
import os
from base64 import b64decode
from urllib.request import Request, urlopen
from urllib.error import URLError, HTTPError
HOOK_URL = os.environ['kmsEncryptedHookUrl']
SLACK_CHANNEL = os.environ['slackChannel']
logger = logging.getLogger()
logger.setLevel(logging.INFO)
def lambda_handler(event, context):
logger.info("Event: " + str(event))
message = event['Records'][0]['Sns']['Message']
logger.info("Message: " + str(message))
alarm_name = message['AlarmName']
new_state = message['NewStateValue']
reason = message['NewStateReason']
slack_message = {
'channel': SLACK_CHANNEL,
'text': "%s state is now %s: %s" % (alarm_name, new_state, reason)
}
req = Request(HOOK_URL, json.dumps(slack_message).encode('utf-8'))
try:
respOnse= urlopen(req)
response.read()
logger.info("Message posted to %s", slack_message['channel'])
except HTTPError as e:
logger.error("Request failed: %d %s", e.code, e.reason)
except URLError as e:
logger.error("Server connection failed: %s", e.reason)

当我运行测试事件时,lambda 运行成功。

我想从控制台在 SNS 主题中发布一条消息,以查看 lambda 是否正确触发。但是当我尝试将 JSON 对象作为消息正文发布时,出现错误

[ERROR] TypeError: string indices must be integersTraceback (most recent call last):  File "/var/task/lambda_function.py", line 21, in lambda_handler    alarm_name = message['AlarmName']

我试着给普通的 json

{
"AlarmName": "PublishedAlarm",
"NewStateValue": "OK",
"NewStateReason": "This alarm is published"
}

我尝试给出一个字符串化的 JSON

"{"AlarmName": "PublishedAlarm","NewStateValue": "OK","NewStateReason": "This alarm is published"}"

我尝试选择Custom payload for each delivery消息结构,然后给出以下消息正文

{
"default": "Sample fallback message",
"email": "Sample message for email endpoints",
"sqs": "Sample message for Amazon SQS endpoints",
"lambda": "{"AlarmName": "PublishedAlarm","NewStateValue": "OK","NewStateReason": "This alarm is published"}",
"http": "Sample message for HTTP endpoints",
"https": "Sample message for HTTPS endpoints",
"sms": "Sample message for SMS endpoints",
"firehose": "Sample message for Amazon Kinesis Data Firehose endpoints",
"APNS": "{"aps":{"alert": "Sample message for iOS endpoints"} }",
"APNS_SANDBOX": "{"aps":{"alert":"Sample message for iOS development endpoints"}}",
"APNS_VOIP": "{"aps":{"alert":"Sample message for Apple VoIP endpoints"}}",
"APNS_VOIP_SANDBOX": "{"aps":{"alert": "Sample message for Apple VoIP development endpoints"} }",
"MACOS": "{"aps":{"alert":"Sample message for MacOS endpoints"}}",
"MACOS_SANDBOX": "{"aps":{"alert": "Sample message for MacOS development endpoints"} }",
"GCM": "{ "data": { "message": "Sample message for Android endpoints" } }",
"ADM": "{ "data": { "message": "Sample message for FireOS endpoints" } }",
"BAIDU": "{"title":"Sample message title","description":"Sample message for Baidu endpoints"}",
"MPNS": "ENTER COUNTSample message for Windows Phone 7+ endpoints",
"WNS": ""
}

没有任何效果。我还订阅了该主题的电子邮件地址,我收到的电子邮件没有任何问题。

如何模拟来自 SNS 的 lambda 事件模板中给出的测试事件?

回答


当您使用 SNS 发送纯 json 消息时,它将以以下格式传送到 lambda:

'Message': '{n "AlarmName": "PublishedAlarm",n "NewStateValue": "OK",n "NewStateReason": "This alarm is published"n}'

您可以使用ast 'literal_eval方法解析它:

import ast
#...
#...
def lambda_handler(event, context):
logger.info("Event: " + str(event))
message = event['Records'][0]['Sns']['Message']
logger.info("Message: " + str(message))
message = ast.literal_eval(event['Records'][0]['Sns']['Message'])
alarm_name = message['AlarmName']
new_state = message['NewStateValue']
reason = message['NewStateReason']
#...
#...






推荐阅读
author-avatar
亲亲羊to
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有