微信机器人底层框架,可接入Gemini、ChatGPT、ChatGLM、讯飞星火、Tigerbot等大模型。WeChat Robot Hook.
Go to file
2023-07-13 23:49:30 +08:00
.github/ISSUE_TEMPLATE Update issue template 2022-11-21 00:31:53 +08:00
docs Fix #47 2023-07-12 23:22:42 +08:00
go go v3.7.0.30.25 2023-05-07 10:53:06 +08:00
http v39.0.0.0 2023-07-13 23:49:30 +08:00
java Remove block comments 2023-05-05 14:14:02 +08:00
launcher Adapt new dll 2023-04-09 15:13:46 +08:00
python v39.0.0.0 2023-07-13 23:49:12 +08:00
rpc Impl Functions_FUNC_DEL_ROOM_MEMBERS 2023-06-29 11:00:05 +08:00
rust 添加踢出群成员函数 2023-07-10 23:07:11 +08:00
sdk Fix log path (Crash) 2023-05-21 20:29:21 +08:00
spy Fix get_self_wxid 2023-07-12 22:42:28 +08:00
wcf Fix log path (Crash) 2023-05-21 20:29:21 +08:00
.editorconfig Switch to UTF-8 BOM to avoid build warning 2022-08-07 22:00:11 +08:00
.gitignore Track *_pb2.py 2023-05-15 17:46:45 +08:00
.readthedocs.yml Update build env 2023-05-04 23:24:47 +08:00
demo.gif Add demo 2022-11-21 00:20:53 +08:00
LICENSE Add LICENSE 2022-09-15 21:22:56 +08:00
QR.jpeg Update QRcode 2023-05-07 09:14:50 +08:00
README.MD Update README 2023-07-01 12:07:53 +08:00
TEQuant.jpg Update QRcode 2023-05-07 09:14:50 +08:00
WeChatFerry.sln Add post build event 2023-02-25 18:04:40 +08:00

WeChatFerry

一个玩微信的工具。更多介绍见:WeChatFerry: 一个玩微信的工具

📖 文档 📺 视频教程 🙋 FAQ

👉 WeChatRobot🤖,一个基于 WeChatFerry 的 Python 机器人框架。

点击查看功能清单
  • 检查登录状态
  • 获取登录账号的 wxid
  • 获取消息类型
  • 获取所有联系人
  • 获取所有好友
  • 获取数据库
  • 获取某数据库下的表
  • 获取用户信息
  • 发送文本消息(可 @
  • 发送图片
  • 发送文件
  • 发送 XML
  • 发送表情
  • 允许接收消息
  • 停止接收消息
  • 执行 SQL 查询
  • 接受好友申请
  • 添加群成员
  • 解密图片
点击查看支持的客户端
  • Go
  • HTTP
  • Java
  • Python
  • Rust

Demo

碲矿 赞赏
后台回复 WeChatFerry 加群交流 如果你觉得有用

快速开始

下载 最新发布的版本。根据技术栈,选择客户端,将相应 dllexe 文件放到对应位置。

Go

参考 Go README.MD

HTTP

PyPi Downloads Documentation Status

  • 安装
pip install --upgrade wcfhttp
  • 运行
# 查看版本
wcfhttp -v

# 查看帮助
wcfhttp -h

# 忽略新消息运行
wcfhttp

# 新消息转发到指定地址
wcfhttp --cb http://your_host:your_port/callback

Java

参考 Java README.MD

Python

PyPi Downloads Documentation Status

  • 安装
pip install --upgrade wcferry

Rust

参考 Rust README.MD

一起开发

安装开发环境

点击查看

安装 vcpkg

cd C:\Tools
git clone https://github.com/microsoft/vcpkg
.\vcpkg\bootstrap-vcpkg.bat
  • 添加全局配置: 环境变量增加 vcpkg 所在路径(本文为:C:\Tools\vcpkg)。

安装相关组件

vcpkg install protobuf[zlib]:x86-windows-static
vcpkg install spdlog:x86-windows-static
vcpkg install nng:x86-windows-static
vcpkg integrate install

安装 VS2019

编译

使用 VS2019 打开工程,编译即可。

运行

双击 Release 里的 launcher.exe启动

项目结构

WeChatFerry
├── docs              # 文档
├── go                # Go 客户端
├── http              # HTTP 客户端
├── java              # Java 客户端
├── launcher          # 图形版启动器
├── python            # Python 客户端
├── rpc               # RPC 模块
├── rust              # Rust 客户端
├── sdk               # 注入及启动模块
├── spy               # 核心功能实现模块
├── wcf               # 命令行版启动器
├── demo.gif          # 示例图
├── LICENSE           # LICENSE
├── README.MD         # 说明
├── TEQuant.jpeg      # 二维码,测试用图
└── WeChatFerry.sln   # VS2019 工程文件
点击查看

go

Go 客户端。

http

HTTP 客户端。

java

Java 客户端。

launcher

⚠️ 不要与客户端同时使用!

图形启动器,调用 sdkspy 注入微信。其他客户端可通过 RPC 连接到 spy 进行消息传递。默认监听的地址为 tcp://0.0.0.0:10086tcp://0.0.0.0:10087

python

Python 客户端。

rpc

RPC 的通信部分和序列化 / 反序列化部分。

rust

Rust 客户端。

sdk

负责将 spy 注入微信进程,并启动 RPC 服务。

spy

间谍模块,注入到微信中,通过 RPC 做消息转发工作。

wcf

launcher 类似,命令行版启动器,一般不需要显式运行,各客户端自动调用。

版本更新

客户端越来越多了,版本号开始混乱,所以重新定义了版本号:w.x.y.z

其中:

  • w 是微信的大版本号,如 37 (3.7.a.a), 38 (3.8.a.a), 39 (3.9.a.a)
  • x 是适配的微信的小版本号,从 0 开始
  • yWeChatFerry 的版本,从 0 开始
  • z 是各客户端的版本,从 0 开始
点击查看

v37.1.25 (2023.05.07)

更新版本编码。

根据新版本编码规则:

  • WeChatFerryv3.7.0.30.25 应调整为:v37.1.25,因为此前曾适配过 3.7.0.29
  • Python 客户端 wcferryv3.7.0.30.25 应该调整为 v37.1.25.0
  • HTTP 客户端 wcfhttpv3.7.0.30.25 应该调整为 v37.1.25.0

v3.7.0.30.25 (2023.05.05)

  • 修复群消息判断错误
  • 修复名片添加好友问题
  • 修复获取数据库多余字符问题
  • 添加 Python 文档
  • Python 客户端发送图片支持网络路径

v3.7.0.30.24 (2023.04.19)

实现了一个功能。

v3.7.0.30.23 (2023.04.13)

  • 解密图片
  • 获取登录账号信息
  • 获取联系人备注

v3.7.0.30.222023.04.09

将监听端口调整为可配置。

v3.7.0.30.212023.03.15

  • 发送表情

v3.7.0.30.202023.03.12

修复 wxid 获取问题。

v3.7.0.30.192023.03.06

修复重复消息问题。

v3.7.0.30.182023.03.05

修复添加好友问题。

v3.7.0.30.172023.03.05

修复获取登录账号 wxid 问题。

v3.7.0.30.162023.03.04

将错误码改成错误消息,方便调试。

v3.7.0.30.152023.03.01

  • 发送 xml

v3.7.0.30.142023.02.28

  • 添加群成员

v3.7.0.30.132023.02.27

去除 gRPC 框架,自定义更轻量的 RPC 轮子 nnprc

v3.7.0.30.122023.01.20

  • 更新 Python 客户端
  • 修改监听地址为 0.0.0.0:10086
  • 增加 Launcher,直接注入 spy

v3.7.0.30.112022.10.19

更新 Python 客户端。

v3.7.0.30-gRPC-22022.10.18

增加 Java 客户端。

v3.7.0.30-gRPC-12022.10.16

将 RPC 框架切换为 gRPC

v3.7.0.30-82022.09.25

  • 获取登录账号微信 ID

v3.7.0.30-72022.09.24

修复群聊有系统消息时会崩溃 bug。后续考虑把消息来源交还给客户端自己区别。

v3.7.0.30-62022.08.21

  • 通过好友验证

v3.7.0.30-52022.08.20

  • 执行 SQL 语句

v3.7.0.30-42022.08.20

修复群消息 @人 功能。有几点注意事项:

  1. vAtWxids 是要 @wxid 清单,以 , 分隔。
  2. 只有群主才能 @所有人,非群主硬发 @所有人 会导致消息发不出去;@所有人 对应 vAtWxids"notify@all"
  3. 消息体里 @ 的数量必须与 vAtWxids 里的数量一致,否则消息能发出但 @ 功能失效。

v3.7.0.30-32022.08.20

修复可重入 bug。

v3.7.0.30-22022.08.14

优化 Hook 和 Inject 代码,实现可重入。

v3.7.0.30-12022.08.12

适配微信 3.7.0.30

v3.7.0.29-32022.08.7

  • 查询数据库,获取库、表。

v3.7.0.29-22022.08.7

优化 RPC。

v3.7.0.29-12022.08.7

适配微信 3.7.0.29

v3.3.0.115-32021.08.28

适配微信 3.3.0.115,新增功能:

  • 获取所有联系人

v3.3.0.115-22021.08.22

适配微信 3.3.0.115,新增功能:

  • 发送图片消息

v3.3.0.115-12021.08.22

适配微信 3.3.0.115

v3.0.0.57-12021.02.12

适配微信 3.0.0.57,支持功能:

  • 登录状态判断
  • 接收文本消息
  • 发送文本消息