我的目标是通过 API Gateway 接收 WhatsApp 消息并将这些消息存储在 DynamoDB 中。我通过我的 webhook 通过以下方式接收数据。我的问题是何时Body
应该将“Hello world”保存到数据库中。它被保存为“Hello+World”。你知道如何避免这种行为吗?
{'SmsMessageSid': 'SMb980630d616e300921cacc5d27835fb1', 'NumMedia': '0', 'SmsSid': 'SMb980630d616e300921cacc5d27835fb1', 'SmsStatus': 'received', 'Body': 'Test+131415+5%2B5%3D10', 'To': 'whatsapp%3A%2B4915734392273', 'NumSegments': '1', 'MessageSid': 'SMb980630d616e300921cacc5d27835fb1', 'AccountSid': 'AC358aa1d18557365a9e1f5e2ffcbcebe0', 'From': 'whatsapp%3A%2B4942357902', 'ApiVersion': '2010-04-01'}
当我打印收到的 webhook 时,我已经看到Body
格式化了“错误”的方式。我尝试了以下
messageBody = event.get('Body')
messageBody = unquote(messageBody)
但这仅解决了现在显示为%2B
的部分%3D
Test+131415+5+5=10
但是,+ 之间的测试 131415 仍然存在。
我的 API Gateway 集成请求中有以下映射模板(在此处找到):
#set($httpPost = $input.path('$').split("&"))
{
#foreach( $kvPair in $httpPost )
#set($kvTokenised = $kvPair.split("="))
#if( $kvTokenised.size() > 1 )
"$kvTokenised[0]" : "$kvTokenised[1]"#if( $foreach.hasNext ),#end
#else
"$kvTokenised[0]" : ""#if( $foreach.hasNext ),#end
#end
#end
}