Install
openclaw skills install openclaw-onebotOneBot 11 channel plugin for QQ messaging (NapCat/go-cqhttp). Native OpenClaw integration with private/group chat, group reactions, block streaming, voice pi...
openclaw skills install openclaw-onebot源码仓库可在 GitHub 查看。
OpenClaw 的 OneBot 11 协议通道插件,让 QQ 成为 OpenClaw 一等消息通道。
支持 NapCat、go-cqhttp 等所有兼容 OneBot 11 协议的 QQ 机器人框架。
说明:
openclaw-onebotopenclaw-onebot-pluginid 是 openclaw-onebotid 仍然是 onebotplugins.allow / plugins.entries 使用 openclaw-onebot;安装记录由 openclaw plugins install 管理channels.onebot 保持不变2026.4.26 / plugin-sdk 2026.4.26,并声明 setupEntry 与 channelConfigs manifest metadataset_msg_emoji_like 给群消息加表情回应;QQ 私聊目前不稳定/通常不生效/status、/help、/commands、/model、/new、/reset 等命令走统一文本命令链路allowFrom 消息来源过滤(私聊/群聊/用户级别)npm run coverage 复核# 自动安装
bash scripts/install.sh
# 或手动(先在仓库根目录准备发布包)
npm install && npm run prepare:clawhub:plugin
openclaw plugins install .clawhub-plugin/openclaw-onebot-plugin --force
scripts/install.sh 会先在源码仓库生成 .clawhub-plugin/openclaw-onebot-plugin 精简发布包,并优先通过 openclaw plugins install 写入新版插件安装索引;旧版 OpenClaw 会回退到手动复制安装。脚本还会自动尝试执行 scripts/sync-openclaw-cli.mjs,把 --shared-dir / --container-shared-dir 接到本机 OpenClaw CLI。
在 openclaw.json 中添加:
{
"plugins": {
"allow": ["openclaw-onebot"],
"entries": {
"openclaw-onebot": {
"enabled": true
}
}
},
"channels": {
"onebot": {
"enabled": true,
"wsUrl": "ws://your-host:3001",
"httpUrl": "http://your-host:3001",
"accessToken": "your_token",
"sharedDir": "/Users/you/napcat/shared",
"containerSharedDir": "/shared",
"groupAutoReact": true,
"groupAutoReactEmojiId": 1
}
}
}
说明:
openclaw-onebotchannels.onebotplugins.installs;新版 OpenClaw 会把插件安装记录保存在托管安装索引中,请使用 openclaw plugins install <path-or-package>也支持环境变量:
ONEBOT_WS_URL=ws://your-host:3001
ONEBOT_HTTP_URL=http://your-host:3001
ONEBOT_ACCESS_TOKEN=your_token # 可选
OneBot setup 也支持:
--token wsUrl,httpUrl[,accessToken[,sharedDir[,containerSharedDir]]]openclaw channels add --channel onebot --shared-dir <hostPath> --container-shared-dir /sharednpm run sync:openclaw-cli 重新同步参数接线openclaw gateway restart
{
"channels": {
"onebot": {
"enabled": true,
"wsUrl": "ws://your-host:3001",
"httpUrl": "http://your-host:3001",
"accessToken": "your_token",
"sharedDir": "/Users/you/napcat/shared",
"containerSharedDir": "/shared",
"allowFrom": ["private:12345", "group:67890"],
"groupAutoReact": true,
"groupAutoReactEmojiId": 1
}
}
}
| 参数 | 说明 |
|---|---|
allowFrom | 消息来源白名单 — private:<QQ号>、group:<群号>、或 *(允许所有) |
accessToken | HTTP API 用 Bearer token,WebSocket 用 query 参数 |
sharedDir | 宿主机共享目录;默认 ~/napcat/shared,用于把语音/图片 stage 给 NapCat |
containerSharedDir | 容器内共享目录;默认 /shared,与 sharedDir 对应 |
groupAutoReact | 是否对入站群消息自动添加 reaction,默认 true |
groupAutoReactEmojiId | 群聊自动 reaction 使用的 QQ emoji id,默认 1 |
reactset_msg_emoji_like 对群消息或指定群消息 message_id 添加表情groupAutoReact / groupAutoReactEmojiId 控制,默认开启{
"agents": {
"defaults": {
"blockStreamingDefault": "on"
}
}
}
{
"channels": {
"onebot": {
"streaming": {
"block": {
"coalesce": {
"minChars": 80,
"idleMs": 600
}
}
}
}
}
}
旧版 channels.onebot.blockStreamingCoalesce 仍兼容;新版 openclaw doctor --fix 会把它迁移到 channels.onebot.streaming.block.coalesce。
msg=<message_id>npm run build
npm run react-test -- --message-id <message_id> --emoji 76
当前建议只把这项验证用于群聊消息;私聊 reaction 在 QQ/NapCat 上通常不生效
Streaming
agents.defaults.blockStreamingDefault = "on"deliver(block),最后再有 deliver(final)支持 QQ 语音消息的完整自动处理链路:
sendRecord 发送 QQ 语音依赖:
ffmpeg — 音频格式转换uv — 运行 pilk 解码 SILK 格式(AMR 仅需 ffmpeg)不需要语音功能时可以跳过这些依赖。
private:<QQ号> — 私聊消息group:<群号> — 群聊消息<QQ号> — 自动识别为私聊npm install
npm test # 119 tests
npm run build # 编译 TypeScript
npm run coverage # 覆盖率报告
npm run sync:openclaw-cli # 重新同步 OpenClaw CLI 的 shared-dir 参数
Source code is available on GitHub.
An OpenClaw native channel plugin that connects to NapCat, go-cqhttp, or any OneBot 11 compatible QQ bot framework.
Note:
openclaw-onebotopenclaw-onebot-pluginid: openclaw-onebotid: onebotopenclaw-onebot in plugins.allow / plugins.entries; install records are managed by openclaw plugins installchannels.onebot unchanged2026.4.26 / plugin-sdk 2026.4.26 and declares setupEntry plus channelConfigs manifest metadataset_msg_emoji_like; QQ private-chat reactions are currently unreliable/status, /help, /commands, /model, /new, /reset, etc.allowFrom filtering (private/group/user-level)npm run coverage# Auto install
bash scripts/install.sh
# Or manual
npm install && npm run prepare:clawhub:plugin
openclaw plugins install .clawhub-plugin/openclaw-onebot-plugin --force
scripts/install.sh prepares .clawhub-plugin/openclaw-onebot-plugin in the source repo first and prefers openclaw plugins install so current OpenClaw builds update the managed plugin install index. Older OpenClaw builds fall back to the legacy manual copy path. The script also runs scripts/sync-openclaw-cli.mjs so the local OpenClaw CLI keeps the OneBot --shared-dir / --container-shared-dir flags wired in.
Add to openclaw.json:
{
"plugins": {
"allow": ["openclaw-onebot"],
"entries": {
"openclaw-onebot": {
"enabled": true
}
}
},
"channels": {
"onebot": {
"enabled": true,
"wsUrl": "ws://your-host:3001",
"httpUrl": "http://your-host:3001",
"accessToken": "your_token",
"sharedDir": "/Users/you/napcat/shared",
"containerSharedDir": "/shared",
"groupAutoReact": true,
"groupAutoReactEmojiId": 1
}
}
}
Notes:
openclaw-onebot for plugin config keyschannels.onebotplugins.installs by hand; current OpenClaw stores install records in a managed plugin index, so use openclaw plugins install <path-or-package>Or via environment variables:
ONEBOT_WS_URL=ws://your-host:3001
ONEBOT_HTTP_URL=http://your-host:3001
ONEBOT_ACCESS_TOKEN=your_token # optional
OneBot setup also supports:
--token wsUrl,httpUrl[,accessToken[,sharedDir[,containerSharedDir]]]openclaw channels add --channel onebot --shared-dir <hostPath> --container-shared-dir /sharednpm run sync:openclaw-cli from the plugin directory to re-apply the flagsopenclaw gateway restart
{
"channels": {
"onebot": {
"enabled": true,
"wsUrl": "ws://your-host:3001",
"httpUrl": "http://your-host:3001",
"accessToken": "your_token",
"sharedDir": "/Users/you/napcat/shared",
"containerSharedDir": "/shared",
"allowFrom": ["private:12345", "group:67890"],
"groupAutoReact": true,
"groupAutoReactEmojiId": 1
}
}
}
| Option | Description |
|---|---|
allowFrom | Whitelist — private:<qq>, group:<id>, or * (allow all) |
accessToken | Bearer token for HTTP, query param for WebSocket |
sharedDir | Host-side shared directory; defaults to ~/napcat/shared for staging outbound media |
containerSharedDir | Container-side mount path; defaults to /shared and should map to sharedDir |
groupAutoReact | Whether to auto-react to inbound group messages; defaults to true |
groupAutoReactEmojiId | QQ emoji id used for automatic group reactions; defaults to 1 |
react channel actionset_msg_emoji_likegroupAutoReact / groupAutoReactEmojiId, enabled by default{
"agents": {
"defaults": {
"blockStreamingDefault": "on"
}
}
}
{
"channels": {
"onebot": {
"streaming": {
"block": {
"coalesce": {
"minChars": 80,
"idleMs": 600
}
}
}
}
}
}
Legacy channels.onebot.blockStreamingCoalesce remains accepted; current openclaw doctor --fix migrates it to channels.onebot.streaming.block.coalesce.
msg=<message_id> from the gateway lognpm run build
npm run react-test -- --message-id <message_id> --emoji 76
For now, treat this as a group-chat verification flow; private-chat reactions are not a reliable capability
Streaming
agents.defaults.blockStreamingDefault = "on" in OpenClaw configdeliver(block) entries in the gateway log, followed by deliver(final)End-to-end voice flow:
sendRecord → QQ voiceDependencies:
ffmpeguv (for SILK decoding via pilk; AMR only needs ffmpeg)Skip these if you only need text and image delivery.
private:<qq_number> — Private messagegroup:<group_id> — Group message<qq_number> — Auto-detected as privatenpm install
npm test # Run 119 tests
npm run build # Compile TypeScript
npm run coverage # Coverage report
npm run sync:openclaw-cli # Re-apply shared-dir CLI wiring after OpenClaw upgrades
MIT