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 · 官网平台

相关推荐
yxl874646462 分钟前
PCTG-1015型Profinet转Ethernet/IP协议转换器
服务器·网络·物联网·网络协议·自动化·信息与通信
你觉得脆皮鸡好吃吗5 分钟前
【THM】JWT Security & Protocols and Servers(AI)
运维·服务器·网络
半导体守望者7 分钟前
MKS C系列MFC CMA10 CMA50快速紧凑型手侧与PC联网教程软件驱动USB
经验分享·笔记·功能测试·自动化·制造
忡黑梨33 分钟前
安装 Claude Code(使用 DeepSeek API)
网络·网络安全
云飞云共享云桌面43 分钟前
搭建10人SolidWorks云设计环境:云飞云在非标自动化工厂的实测方案
运维·服务器·网络·数据库·自动化·电脑
江畔柳前堤1 小时前
第07章:Docker 网络模型
运维·网络·git·elasticsearch·docker·容器·架构
云飞云共享云桌面1 小时前
智能装备制造数字化实测:10人SolidWorks云桌面部署,云飞云方案替代传统单机工作站
运维·服务器·网络·人工智能·制造
Urbano1 小时前
突破品类边界:数控模板机不止制衣,枕套等家居家纺自动化生产全科普
运维·自动化
江畔柳前堤1 小时前
第17章:Docker 大厂面试题精选(腾讯/阿里/字节/美团)
运维·网络·spring cloud·docker·容器·eureka
AI视频剪辑官1 小时前
播客切片工具选型核心评价维度
网络·人工智能·算法