Facebook Send API提及"有效载荷"您可以为通用响应模板上的按钮设置类型。但是,他们不会说它是如何运作的,除了:
对于回发按钮,此数据将通过webhook
发回给您
但是如何送回?单击有效负载按钮时,我没有收到任何消息。有没有人成功使用它?
答案 0 :(得分:6)
我测试了它,它适用于我。按钮的有效负载与html按钮上的值相似。这意味着用户看不到它,但它的价值是发回给您的。
如果你创建一个这样的按钮:
'attachment': {
'type': 'template',
'payload': {
'template_type': 'button',
'text': 'This is the description',
'buttons': [
{
'type': 'postback',
'title': 'This is the visible text',
'payload': 'This is the value you get back'
}
]
}
包含有效负载的回调类似于:
{'timestamp': 1461697120850, 'postback': {'payload': 'this is the value you get back'}, 'recipient': {'id': xxxxxxxx}, 'sender': {'id': xxxxxxxx}}
答案 1 :(得分:5)
当您点击按钮时,POST消息将发送到您的/webhook
。
你必须像这样处理有效载荷:
app.post('/webhook/', function (req, res) {
messaging_events = req.body.entry[0].messaging;
for (i = 0; i < messaging_events.length; i++) {
event = req.body.entry[0].messaging[i];
sender = event.sender.id;
if (event.message && event.message.text) {
text = event.message.text;
// Handle a text message from this sender
} else if (event.postback && event.postback.payload) {
payload = event.postback.payload;
// Handle a payload from this sender
}
}
res.sendStatus(200);
});
此代码段来自Facebook的入门指南,但else if
除外,您可以对有效负载做出反应。
答案 2 :(得分:0)
这是你回读有效载荷的方式:
$payload = $input['entry'][0]['messaging'][0]['postback']['payload'];