一个基于 AutoJS6 的 VX 自动化机器人框架。支持自动回复、OpenAI 对话、视频下载、图片发送、会话管理等功能。
⚠️ 免责声明: 本项目仅供学习与技术研究,请勿用于发送垃圾信息或骚扰他人。使用者需自行承担风险。
- ⚡️ 异步并行: 采用生产者-消费者模型,多任务并行处理,响应迅速
- 🔒 线程安全: 使用 Lock 保护发送队列,确保消息准确投递
- 📲 Intent 分享: 视频/图片采用 Android Intent 机制直接分享,无需进入会话
- 🎬 VideoBot: 支持各视频平台视频解析下载并分享
- 🖼 ImageBot: 发送随机风景美图 (Picsum)
- 🤖 OpenAIBot: 多轮对话、上下文记忆、智能引用处理
- 💬 消息引用: 回复自带原消息引用,支持智能解析引用格式
- 🛡 智能去重: 双重保护 - 处理窗口去重 (5s) + 已回复去重 (120s TTL)
- 📡 主动轮询: 列表轮询机制,主动扫描未读消息
- 👥 群聊优化: 支持群聊 @机器人 触发,群聊回复自动 @发送者
- 安卓手机一台 (建议 Android 7.0+)
- 安装 AutoJS6
- 安装 VX 8.0.39 (版本差异可能导致 UI 查找失败)
- 安装 Node.js (用于本地构建)
# 安装依赖
npm install
# 构建
npm run demo构建完成后,会在 dist/ 目录下生成 VXBot.js。
将 config.json.example 复制并重命名为 config.json,和 VXBot.js 放在同一目录,编辑填入你的实际配置。
- 将
VXBot.js和config.json发送到手机同一目录 - 在 AutoJS6 中运行
VXBot.js - 授予必要的权限 (无障碍服务、悬浮窗)
- 脚本会自动启动 VX 并开始工作
💡 提示: 修改
config.json后只需重启脚本即可生效,无需重新构建!
| 功能 | 触发方式 | 说明 |
|---|---|---|
| AI 对话 | 发送文本 | 默认由 ChatGPT 回复 |
| 视频下载 | 下载 [链接] |
支持各视频平台分享短语 |
| 发送图片 | 发图 |
精确匹配指令 |
| 群聊召唤 | @机器人名 消息 |
例如:@Bot 讲个笑话 |
配置文件查找顺序:
- 脚本同目录
./config.json(推荐) - 全局路径
/sdcard/VXBot/config.json
参考 config.json.example 创建配置文件:
{
"whitelist": ["好友A", "技术交流群"],
"mentionString": "@Bot",
"polling": {
"enabled": true,
"interval": 500
},
"asyncMode": true,
"plugins": {
"openai": {
"enabled": true,
"apiKey": "sk-xxxx",
"baseUrl": "https://api.openai.com/v1",
"model": "gpt-4"
},
"video": {
"enabled": true,
"serverUrl": "http://127.0.0.1:8080",
"command": "下载"
},
"image": {
"enabled": true,
"command": "发图"
}
}
}| 配置项 | 类型 | 说明 |
|---|---|---|
whitelist |
Array | 会话白名单,留空则响应所有会话 |
mentionString |
String | 群聊触发词 (如 @Bot),留空则响应所有消息 |
polling.enabled |
Boolean | 是否开启主动轮询 |
polling.interval |
Number | 轮询间隔 (毫秒) |
asyncMode |
Boolean | 异步模式,推荐开启 |
plugins.*.enabled |
Boolean | 各插件开关 |
💡 提示: 修改配置后只需重启 AutoJS6 脚本即可生效,无需重新构建!
VXBot/
├── config.json.example # 配置模板
├── config.json # 你的配置 (gitignore)
├── demo.js # 入口脚本 (gitignore)
├── package.json # 项目依赖
├── dist/
│ └── VXBot.js # 构建产物
└── src/
├── bot.js # 核心调度器
├── modules/
│ └── vchat.js # VX UI 适配层
└── plugins/
├── openai_bot.js # AI 对话插件
├── image_bot.js # 发图插件
└── video_bot.js # 视频下载插件
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ Polling │ ──▶ │ Dispatcher │ ──▶ │ Plugins │
│ (Producer) │ │ (Router) │ │ (Handlers) │
└─────────────┘ └─────────────┘ └─────────────┘
│ │
│ ┌─────────────┐ │
└────────────▶ │ Send Queue │ ◀────────┘
│ (Consumer) │
└─────────────┘
特别感谢 tmkook/vchat 项目提供的基础思路与核心代码实现。
MIT