企业微信智能机器人(AI Bot)是企业微信官方提供的 AI 对话接入方式,支持私聊与群聊,内置流式响应协议,并支持超时后通过 response_url 主动推送最终回复。
| 特性 | WeCom Bot | WeCom App | WeCom AI Bot |
|---|---|---|---|
| 私聊 | ✅ | ✅ | ✅ |
| 群聊 | ✅ | ❌ | ✅ |
| 流式输出 | ❌ | ❌ | ✅ |
| 超时主动推送 | ❌ | ✅ | ✅ |
| 配置复杂度 | 低 | 高 | 中 |
{
"channels": {
"wecom_aibot": {
"enabled": true,
"token": "YOUR_TOKEN",
"encoding_aes_key": "YOUR_43_CHAR_ENCODING_AES_KEY",
"webhook_path": "/webhook/wecom-aibot",
"allow_from": [],
"welcome_message": "你好!有什么可以帮助你的吗?",
"max_steps": 10
}
}
}| 字段 | 类型 | 必填 | 描述 |
|---|---|---|---|
| token | string | 是 | 回调验证令牌,在 AI Bot 管理页面配置 |
| encoding_aes_key | string | 是 | 43 字符 AES 密钥,在 AI Bot 管理页面随机生成 |
| webhook_path | string | 否 | Webhook 路径(默认:/webhook/wecom-aibot) |
| allow_from | array | 否 | 用户 ID 白名单,空数组表示允许所有用户 |
| welcome_message | string | 否 | 用户进入聊天时发送的欢迎语,留空则不发送 |
| reply_timeout | int | 否 | 回复超时时间(秒,默认:5) |
| max_steps | int | 否 | Agent 最大执行步骤数(默认:10) |
- 登录 企业微信管理后台
- 进入"应用管理" → "智能机器人",创建或选择一个 AI Bot
- 在 AI Bot 配置页面,填写"消息接收"信息:
- URL:
http://<your-server-ip>:18791/webhook/wecom-aibot - Token:随机生成或自定义
- EncodingAESKey:点击"随机生成",得到 43 字符密钥
- URL:
- 将 Token 和 EncodingAESKey 填入 PicoClaw 配置文件,启动服务后回到管理后台保存(企业微信会发送验证请求)
Tip
服务器需要能被企业微信服务器访问。如在内网/本地开发,可使用 ngrok 或 frp 做内网穿透。
WeCom AI Bot 使用"流式拉取"协议,区别于普通 Webhook 的一次性回复:
用户发消息
│
▼
PicoClaw 立即返回 {finish: false}(Agent 开始处理)
│
▼
企业微信每隔约 1 秒拉取一次 {msgtype: "stream", stream: {id: "..."}}
│
├─ Agent 未完成 → 返回 {finish: false}(继续等待)
│
└─ Agent 完成 → 返回 {finish: true, content: "回答内容"}
超时处理(任务超过 30 秒):
若 Agent 处理时间超过约 30 秒(企业微信最大轮询窗口为 6 分钟),PicoClaw 会:
- 立即关闭流,向用户显示「⏳ 正在处理中,请稍候,结果将稍后发送。」
- Agent 继续在后台运行
- Agent 完成后,通过消息中携带的
response_url将最终回复主动推送给用户
response_url由企业微信颁发,有效期 1 小时,只可使用一次,无需加密,直接 POST markdown 消息体即可。
配置 welcome_message 后,当用户打开与 AI Bot 的聊天窗口时(enter_chat 事件),PicoClaw 会自动回复该欢迎语。留空则静默忽略。
"welcome_message": "你好!我是 PicoClaw AI 助手,有什么可以帮你?"- 确认服务器防火墙已开放对应端口(默认 18791)
- 确认
token与encoding_aes_key填写正确 - 检查 PicoClaw 日志是否收到了来自企业微信的 GET 请求
- 检查
allow_from是否意外限制了发送者 - 查看日志中是否出现
context canceled或 Agent 错误 - 确认 Agent 配置(
model_name等)正确
- 确认消息回调中携带了
response_url(仅企业微信新版 AI Bot 支持) - 确认服务器能主动访问外网(需向
response_urlPOST 请求) - 查看日志关键词
response_url mode和Sending reply via response_url