NodeJS slack events API通过一条消息触发多次

beq87vna  于 2023-04-20  发布在  Node.js
关注(0)|答案(4)|浏览(117)

我正在使用Slack API从Slack工作区获取链接。它可以工作,除非发布消息时,它会触发不止一次。每次。下面是我的代码:

exports.slack = (req , res) => {    
var message = req.body;

if (message.challenge) {
     res.send(message.challenge);

} else if (message.event.type == 'message_received') {
    if (message.event.text.includes('<')) {
        // Link
        console.log('NEW LINK');

        var link = message.event.text.slice(1, -1); 

        getArticleInfo(link, (error, body) => {
            if (error) 
                console.error(error);
            else {
                newArticleToDB(body , link, req);
            }
        });  
    }
  } 
}

每次有新消息发布,我都会多次收到“新链接”日志。有什么想法可以在哪里寻找这个问题吗?
谢谢。

gdx19jrr

gdx19jrr1#

我添加了res.sendStatus(200),现在一切都像预期的那样工作。下面是代码:

exports.slack = (req , res) => {    
var message = req.body;
res.sendStatus(200);

if (message.challenge) {
    res.send(message.challenge);

} else if (message.event.type == 'message' && message.event.subtype != 'message_changed') {
    if (message.event.text && message.event.text.includes('<')) {
        // Link
        console.log('NEW LINK');

        var link = message.event.text.slice(1, -1); 

        getArticleInfo(link, (error, body) => {
            if (error) 
                console.error(error);
            else {
                newArticleToDB(body , link, req);
            }
        });  
    }
}
nwlls2ji

nwlls2ji2#

我有这个问题,谢谢@taylor-singletary的建议。我不得不打印

console.log('Request Headers::: ', JSON.stringify(req.headers));

寻找

"x-slack-retry-num":"1"

要获取header值,只需参考以下问题:How to extract request http headers from a request using NodeJS connect

ruyhziif

ruyhziif3#

我在接收多个事件时也遇到了同样的问题。结果是我添加的每个bot用户事件都接收到1个事件。我不知道这是否是API的预期行为,但我决定删除除app_mention之外的所有事件,现在我只接收到1个事件。

fwzugrvs

fwzugrvs4#

响应事件

您的应用应在三秒内使用HTTP 2xx响应事件请求。如果没有,我们将认为事件交付尝试失败。失败后,我们将重试三次,以指数方式后退。一些最佳实践是:
1.保持每60分钟至少5%的事件响应成功率,以防止自动禁用。
1.尽快使用HTTP 200 OK响应事件。
1.避免在同一进程中实际处理和响应事件。
1.实现队列以在接收到入站事件后处理它们。
如何处理事件取决于应用程序或服务的功能。
也许它会触发你使用chat.postMessage发送消息,也许你会更新排行榜,也许你会更新你存储的一段数据,也许你会改变世界,或者只是决定什么都不做。
参考:https://api.slack.com/apis/connections/events-api#graceful_retries

相关问题