使用相同的 Facebook 入门指南时 (https://developers.facebook.com/docs/messenger-platform/quickstart)
在输入消息并将其发送到机器人时,我在 Node.js 控制台上收到错误。
{ error:
{ message: '(#100) No matching user found',
type: 'OAuthException',
code: 100,
fbtrace_id: 'BLguK1o+VsH' } } }
我有最新版本的node.js,并且正在使用 Ngrok 公开我的本地主机。
我的 app.post 例程如下:(这是入门指南的精确副本)
router.post('/webhook', function (req, res) {
var data = req.body;
// Make sure this is a page subscription
if (data.object == 'page') {
// Iterate over each entry
// There may be multiple if batched
data.entry.forEach(function(pageEntry) {
var pageID = pageEntry.id;
var timeOfEvent = pageEntry.time;
// Iterate over each messaging event
pageEntry.messaging.forEach(function(messagingEvent) {
if (messagingEvent.optin) {
receivedAuthentication(messagingEvent);
} else if (messagingEvent.message) {
receivedMessage(messagingEvent);
} else if (messagingEvent.delivery) {
receivedDeliveryConfirmation(messagingEvent);
} else if (messagingEvent.postback) {
receivedPostback(messagingEvent);
} else {
console.log("Webhook received unknown messagingEvent: ", messagingEvent);
}
});
});
// Assume all went well.
//
// You must send back a 200, within 20 seconds, to let us know you've
// successfully received the callback. Otherwise, the request will time out.
// res.sendStatus(200);
}
});
这是正在调用的 receiveMessage 函数
function receivedMessage(event) {
var senderID = event.sender.id;
var recipientID = event.recipient.id;
var timeOfMessage = event.timestamp;
var message = event.message;
console.log("Received message for user %d and page %d at %d with message:",
senderID, recipientID, timeOfMessage);
console.log(JSON.stringify(message));
var messageId = message.mid;
// You may get a text or attachment but not both
var messageText = message.text;
var messageAttachments = message.attachments;
if (messageText) {
// If we receive a text message, check to see if it matches any special
// keywords and send back the corresponding example. Otherwise, just echo
// the text we received.
switch (messageText) {
case 'image':
sendImageMessage(senderID);
break;
case 'button':
sendButtonMessage(senderID);
break;
case 'generic':
sendGenericMessage(senderID);
break;
case 'receipt':
sendReceiptMessage(senderID);
break;
default:
//getArticles(function(err,articles){
// sendTextMessage(senderID, articles[0].text);
//});
sendTextMessage(senderID, messageText);
/* client.converse('my-user-session-42', messageText, {})
.then((data) => {
console.log('the question asked :' + messageText);
sendTextMessage(senderID, data.msg);
console.log('Yay, got Wit.ai response: ' + JSON.stringify(data));
}).catch(console.error);
*/
}
} else if (messageAttachments) {
sendTextMessage(senderID, "Message with attachment received");
}
}
更多以下是我的要求声明:
const bodyParser = require('body-parser');
var express = require('express');
var request = require('request');
var router = express.Router();
const fetch = require('node-fetch');
const {Wit, log} = require('node-wit');
这是其余使用的功能:
function sendTextMessage(recipientId, messageText) {
var messageData = {
recipient: {
id: recipientId
},
message: {
text: messageText
}
};
callSendAPI(messageData);
}
function callSendAPI(messageData) {
request({
uri: 'https://graph.facebook.com/v2.6/me/messages',
qs: { access_token: PAGE_ACCESS_TOKEN },
method: 'POST',
json: messageData
}, function (error, response, body) {
if (!error && response.statusCode == 200) {
var recipientId = body.recipient_id;
var messageId = body.message_id;
console.log("Successfully sent generic message with id %s to recipient %s",
messageId, recipientId);
} else {
console.error("Unable to send message.");
console.error(response);
console.error(error);
}
});
}
所以我在某处读到这一切都与页面 id 或 facebook 处理整数的方式有关,但我有点困惑。
任何帮助将不胜感激。
出现此错误的原因是使用了不正确的令牌将消息发送回机器人。确保您拥有正确的(即使一开始就对其进行硬编码),可以从您的 Developers.facebook.com 页面的 Messenger -> 设置 -> 令牌生成下复制它。
您只需要绕过您自己的消息即可。
您的机器人有一个唯一的 ID(不是应用程序 ID),因此您可以在 POST 逻辑中尝试此解决方法:
var myID = '...' ;
.....
event = req.body.entry[0].messaging[i];
sender = event.sender.id;
if (event.message && event.message.text && sender != myID) {
.....
}
您可以通过查看您的消息来获取您的机器人 ID:
"sender":{
"id":"USER_ID"
},
JSON 示例:
even.message:
{"sender":{"id":"**yourBotID**"},
"recipient":{"id":"**clientID**"},
"timestamp":1468241667962,
"message": {"**is_echo":true**,
"app_id":**appID**,
"mid":"mid....",
"seq":617,"text":"..."}}
提示:要识别您的 BotID,只需在消息负载中查找 "message": {"is_echo": true,..。
问候
我进入 Facebook Messenger 设置 -> Webhooks -> 编辑事件并从订阅的事件中删除了Messenger_echoes。这解决了这个问题。
我遵循了本指南http://x-team.com/2016/04/how-to-get-started-with-facebook-messenger-bots/
一切顺利:
我已在下面发布了我的代码:
'use strict'
const bodyParser = require('body-parser');
var express = require('express');
var request = require('request');
var app = express();
const fetch = require('node-fetch');
const {Wit, log} = require('node-wit');
app.use(bodyParser.urlencoded({extended: false}))
var PAGE_ACCESS_TOKEN = '********'
var MY_TOKEN = '********';
// Wit.ai code
const client = new Wit({accessToken: '*********'});
// GET home page.
app.get('/', function(req, res, next) {
res.render('index', { title: 'Express' });
});
app.get('/webhook/', function(req, res) {
if (req.query['hub.mode'] === 'subscribe' &&
req.query['hub.verify_token'] === 'hello_token_success') {
console.log("Validating webhook");
res.status(200).send(req.query['hub.challenge']);
} else {
console.error("Failed validation. Make sure the validation tokens match.");
res.sendStatus(403);
}
});
//** Receive Messages **
app.post('/webhook/', function (req, res) {
var data = req.body;
var events = req.body.entry[0].messaging;
for (var i = 0; i < events.length ; i++) {
var event = events[i];
if (event.message && event.message.text && !event.message.is_echo) {
var text = event.message.text;
sendTextMessage(event.sender.id, "Text received, echo: "+ text.substring(0, 200));
}
}
// Assume all went well.
//
// You must send back a 200, within 20 seconds, to let us know you've
// successfully received the callback. Otherwise, the request will time out.
res.sendStatus(200);
});
function receivedMessage(event) {
var senderID = event.sender.id.toString();
var recipientID = event.recipient.id.toString();
var timeOfMessage = event.timestamp;
var message = event.message;
console.log("Received message for user %d and page %d at %d with message:",
senderID, recipientID, timeOfMessage);
console.log(JSON.stringify(message));
var messageId = message.mid;
// You may get a text or attachment but not both
var messageText = message.text;
var messageAttachments = message.attachments;
if (messageText && !message.is_echo) {
// If we receive a text message, check to see if it matches any special
// keywords and send back the corresponding example. Otherwise, just echo
// the text we received.
switch (messageText) {
case 'image':
sendImageMessage(senderID);
break;
case 'button':
sendButtonMessage(senderID);
break;
case 'generic':
sendGenericMessage(senderID);
break;
case 'receipt':
sendReceiptMessage(senderID);
break;
default:
sendTextMessage(senderID, messageText);
}
} else if (messageAttachments) {
sendTextMessage(senderID, "Message with attachment received");
}
}
function sendGenericMessage(recipientId) {
var messageData = {
recipient: {
id: recipientId
},
message: {
attachment: {
type: "template",
payload: {
template_type: "generic",
elements: [{
title: "rift",
subtitle: "Next-generation virtual reality",
item_url: "https://www.oculus.com/en-us/rift/",
image_url: "http://messengerdemo.parseapp.com/img/rift.png",
buttons: [{
type: "web_url",
url: "https://www.oculus.com/en-us/rift/",
title: "Open Web URL"
}, {
type: "postback",
title: "Call Postback",
payload: "Payload for first bubble",
}],
}, {
title: "touch",
subtitle: "Your Hands, Now in VR",
item_url: "https://www.oculus.com/en-us/touch/",
image_url: "http://messengerdemo.parseapp.com/img/touch.png",
buttons: [{
type: "web_url",
url: "https://www.oculus.com/en-us/touch/",
title: "Open Web URL"
}, {
type: "postback",
title: "Call Postback",
payload: "Payload for second bubble",
}]
}]
}
}
}
};
callSendAPI(messageData);
}
function receivedPostback(event) {
var senderID = event.sender.id;
var recipientID = event.recipient.id;
var timeOfPostback = event.timestamp;
// The 'payload' param is a developer-defined field which is set in a postback
// button for Structured Messages.
var payload = event.postback.payload;
console.log("Received postback for user %d and page %d with payload '%s' " +
"at %d", senderID, recipientID, payload, timeOfPostback);
// When a postback is called, we'll send a message back to the sender to
// let them know it was successful
sendTextMessage(senderID, "Postback called");
}
function sendTextMessage(recipientId, messageText) {
var messageData = {
recipient: {
id: recipientId
},
message: {
text: messageText
}
};
callSendAPI(messageData);
}
function callSendAPI(messageData) {
request({
uri: 'https://graph.facebook.com/v2.6/me/messages',
qs: { access_token: PAGE_ACCESS_TOKEN },
method: 'POST',
json: messageData
}, function (error, response, body) {
if (!error && response.statusCode == 200) {
var recipientId = body.recipient_id;
var messageId = body.message_id;
console.log("Successfully sent generic message with id %s to recipient %s",
messageId, recipientId);
} else {
console.error("Unable to send message.");
console.error(response);
console.error(error);
}
});
}
module.exports = app;
确保您使用了正确的收件人 ID。收件人不是页面或应用程序 ID,而是用户的 ID(如果您想向用户发送消息)。
您可以配置 webhook,例如 https://requestb.in 并检查来自 Messenger 的请求,您要查找的 ID 是:
{"sender":{"id":"1499894473423552"}}
我想分享我的经验。我在调用 v15.0/me/messages API 时遇到了同样的错误。
我正在使用我的应用程序的测试版本。当我开始直接使用我的应用程序时,错误消失了。至少对于我来说,测试应用程序似乎不会查找用户。
我删除了事件中的消息回显,并仅选择消息传递和回发,它解决了问题
对我来说,我试图使用这些字段来访问用户API
first_name,last_name,locale,gender,profile_pic,timezone
,我刚刚删除了profile_pic
并且它起作用了,我开始使用picture
字段来代替