Webhook 驱动:企业微信消息接收与自动回复

只调 sendText 是单向推送。AI 客服、关键词应答、工单采集都要 收消息 → 处理 → 再发。RPA 连接器在控制台配置 Webhook 后,执行节点收到的好友消息、群消息会 POST 到你的服务,你再调发送接口回复。

和官方「应用回调」不同:这里通常不需要企业侧部署消息加解密服务,但事件结构以平台文档为准,联调时先全量打日志。

方案说明

数据方向

复制代码
用户发企微消息
    ↓
执行节点接收
    ↓
平台 POST Webhook(JSON)
    ↓
你的服务:幂等 → 入队 → 业务逻辑 → sendText 回复

回调服务三原则

  1. 快速 200 --- 几秒内返回;调 LLM、写库放异步 worker。

  2. 幂等 --- 用消息 ID 去重,避免重复回复。

  3. 分类型 --- 文本、图片、群 @ 等分支不同,别写死只处理一种。

测收消息的常见误区

用 sendText 发出去再等同一条回调,往往收不到。应让外部用户或同事给该节点发消息,再看 Webhook 是否触发。

操作步骤

  1. 节点在线,Token 就绪。

  2. 部署公网 HTTPS 的 /webhook/qw;本地用内网穿透。

  3. 控制台保存 Webhook URL,确认验证请求能 200。

  4. 外部号发测试私聊,服务端打印完整 Body。

  5. 写 handler:文本 → 调 sendText 回声。

  6. 外部群测 @ 或关键词;私聊与群聊分支分开。

  7. 生产用 Redis 存已处理消息 ID。

示例代码

python 复制代码
from flask import Flask, request
from threading import Thread
import requests
import os

app = Flask(__name__)
GATEWAY = os.environ["QW_GATEWAY"]
TOKEN = os.environ["QW_API_TOKEN"]
_seen = set()

def send_text(guid, toid, content):
    requests.post(
        f"{GATEWAY}/qw/doApi",
        json={"method": "/msg/sendText", "params": {
            "guid": guid, "toid": toid, "content": content,
        }},
        headers={"X-API-TOKEN": TOKEN, "Content-Type": "application/json"},
        timeout=15,
    )

def handle(event):
    msg_id = event.get("msgId") or event.get("id")
    if msg_id and msg_id in _seen:
        return
    if event.get("msgType") != "text":
        return
    guid = event["guid"]
    sender = event.get("fromId")
    room = event.get("roomId")
    toid = room if room else sender
    text = event.get("content", "")
    send_text(guid, toid, f"已收到:{text}")
    if msg_id:
        _seen.add(msg_id)

@app.post("/webhook/qw")
def webhook():
    event = request.get_json(force=True)
    Thread(target=handle, args=(event,), daemon=True).start()
    return {"code": 0}, 200

注意

  • 群消息回复时,toid 通常是 roomId;发送者 ID 用于识别谁触发。

  • 实例掉线后回调不稳定,先查节点状态。

  • 内存去重重启会丢,生产用 Redis。

  • 日志注意脱敏,控制聊天记录留存周期。

  • 前面有 Nginx 时注意超时和 Body 大小限制。

文档

API 文档 · Webhook · 官网平台

相关推荐
弹简特1 小时前
【接口自动化】04-requests模块详解及接口关联
自动化·requests
不吃土豆的马铃薯1 小时前
C++ 正则表达式入门详解
linux·服务器·网络·数据库·c++·正则表达式
delishcomcn2 小时前
AI赋能的薄膜分切机:从自动化到自优化
运维·人工智能·自动化·薄膜分切机
极客先躯2 小时前
高级java每日一道面试题-2026年02月03日-实战篇[Docker]-如何备份和恢复 Docker Volume?
运维·docker·容器·自动化·备份·持久化·恢复
艾莉丝努力练剑2 小时前
【Qt】界面优化:绘图API
linux·运维·开发语言·网络·qt·tcp/ip·udp
行走__Wz2 小时前
【网工入门-05】网络参考模型
网络
艾莉丝努力练剑2 小时前
【Linux网络】NAT、内网穿透、内网打洞
linux·运维·服务器·网络·计算机网络·udp·php
带娃的IT创业者2 小时前
从天津“工业机器人天团”看现代智能制造的技术架构演进
架构·机器人·制造·智能制造·运动控制·工业机器人·技术架构
零陵上将军_xdr2 小时前
Shell函数与自动化:让脚本从“能用“进化到“好用“
运维·自动化