1

我的目标是通过 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
}
4

1 回答 1

0

这里的解决方案:urllib.parse.unquote_plus

于 2019-11-23T15:44:02.317 回答