【发布时间】:2020-09-16 23:12:44
【问题描述】:
我在 AWS Lambda 中有以下 Python 代码来验证收到的事件是否确实来自 Slack:
import hmac
import json
def verifySignature(header,body):
h = hmac.new(key=os.getenv('sign_secret').encode(), \
msg=f'v0:{header.get("X-Slack-Request-Timestamp")}:{body}'.encode(), \
digestmod="sha256")
result = hmac.compare_digest('v0='+h.hexdigest(),header.get('X-Slack-Signature'))
print('v0='+h.hexdigest(),header.get('X-Slack-Signature'))
return result
def lambda_handler(event, context):
body = json.loads(event.get('body'))
if verifySignature(event.get('headers'),body):
do_something()
概述了 Slack 的身份验证协议 here。但是,我不断收到不匹配的签名(结果 == False)。有谁知道为什么?
【问题讨论】:
标签: json python-3.x amazon-web-services aws-lambda slack-api