微信机器人(iLink Bot)只能被动回复用户消息,不能主动发起对话。
这意味着 agent 没法做定时提醒、告警推送、报告发送等主动触达场景。
这个技能通过 wxclawbot CLI 让 agent 能主动给微信用户推送消息,
包括文本、图片、视频、文件。配合 cron 可实现定时任务。
npm install -g @claw-lab/wxclawbot-cli~/.openclaw/openclaw-weixin/accounts/)验证: wxclawbot accounts --json
wxclawbot send --text "消息内容" --json
wxclawbot send --file ./photo.jpg --json
wxclawbot send --file ./report.pdf --text "请查收" --json
主动发文本消息 → wxclawbot send --text "msg" --json
主动发文件/图片 → wxclawbot send --file ./path --json
检查账号状态 → wxclawbot accounts --json
编程调用 → see references/programmatic-api.md
wxclawbot send --text "message" --json
wxclawbot send --to "user@im.wechat" --text "你好" --json
wxclawbot send --file ./photo.jpg --json
wxclawbot send --file ./report.pdf --text "请查收" --json
wxclawbot send --file "https://example.com/img.png" --json
echo "日报已生成" | wxclawbot send --json
wxclawbot send --text "test" --dry-run
| 参数 | 说明 |
|---|---|
| ------ | ------ |
--text | 消息文本。"-" 显式读 stdin |
--file | 本地文件或 URL(图片 / 视频 / 文件) |
--to | 目标用户 ID。默认: 账号绑定用户 |
--account | 指定账号。默认: 第一个可用的 |
--json | JSON 格式输出。编程调用必须带上 |
--dry-run | 预览,不发送 |
媒体类型按扩展名自动识别:
wxclawbot accounts --json
返回: [{"id":"
CLI 自动从 ~/.openclaw/openclaw-weixin/accounts/*.json 发现账号。
每个文件包含 token, baseUrl, userId(默认 --to 目标)。
--to 默认是账号文件里的 userId(绑定用户)WXCLAW_TOKEN 环境变量会覆盖文件发现微信要求 context_token 才能主动推送消息。没有它,消息会留在服务器上,
直到用户主动打开聊天窗口才能看到——这就不叫"主动推送"了。
CLI 自动读取 {accountId}.context-tokens.json(和账号文件同目录)。
这个文件由 openclaw-weixin 维护,格式是 userId → contextToken 的映射。
不需要手动配置——用户给机器人发过消息后 openclaw-weixin 会自动保存。
如果 context_token 缺失(新用户、token 过期),消息仍然会发送成功
(ok:true),但不会主动推送通知。
升级 openclaw-weixin 后,务必用 wxclawbot accounts --json 验证。
编程调用必须用 --json。解析 JSON 判断是否成功。
result=$(wxclawbot send --text "任务完成" --json)
result=$(wxclawbot send --file ./chart.png --text "每日指标" --json)
{"ok":true,"to":"user@im.wechat","clientId":"..."}{"ok":false,"error":"..."}注意: exit 0 只代表 CLI 跑完了,不代表消息送达。看 ok 字段。
| 错误 | 含义 | 处理 |
|---|---|---|
| ------ | ------ | ------ |
ret=-2 | 频率限制(每 bot 约 7 条 / 5 分钟,所有客户端共享) | 等 60-120 秒重试,别搞紧循环 |
ret=-14 | 会话过期 | 通过 openclaw 重新登录 |
| No account found | 凭证缺失 | 跑 wxclawbot accounts 排查 |
| CDN upload error | 文件上传失败 | 检查文件大小 / 格式,重试 |
| Request timeout | 网络问题(15 秒超时) | 重试 |
频率限制是服务端的,同一个 bot token 下所有客户端共享配额。
--json 模式下,传输层失败会包含额外字段:
{"ok":false,"error":"send failed: ...","errorKind":"timeout","retryable":true}
errorKind | 含义 | retryable |
|---|---|---|
| ------------- | ------ | ------------- |
timeout | 请求超过 15 秒 | true |
dns | DNS 解析失败 | true |
connection | 连接重置 / socket hang up | true |
network | 连接被拒 / 主机不可达 / fetch failed | true |
tls | 证书或 TLS 错误 | false |
unknown | 未分类错误 | false |
用 retryable 字段判断应该重试还是直接失败。
--json —— 不带的话输出是人类可读格式,没法解析ok 字段 —— exit 0 只代表 CLI 跑了,不代表消息到了ret=-2 —— 至少等 5-10 秒echo "..." | wxclawbot send --json,避免 shell 引号问题| 变量 | 用途 |
|---|---|
| ------ | ------ |
WXCLAW_TOKEN | 覆盖 bot token (bot@im.bot:your-token) |
WXCLAW_BASE_URL | 覆盖 API 端点 (默认: https://ilinkai.weixin.qq.com) |
编程接口详见 references/programmatic-api.md。
共 1 个版本