wechat hook 。支持3.8.0.41,3.8.1.26, 3.9.0.28, 3.9.2.23版本。
Go to file
2023-08-31 08:44:35 +08:00
.github/ISSUE_TEMPLATE Update issue templates 2023-04-17 16:35:59 +08:00
doc feat: 发送小程序(待完善) 2023-08-31 08:44:35 +08:00
java_client 提取实现类,只需要实现方法即可完成 2023-06-06 16:50:52 +08:00
python feat:新增发送公众号消息,下载附件,图片解码,获取语音,发送自定义表情 2023-08-31 08:44:35 +08:00
source feat: 邀请入群,hook日志 2023-08-31 08:44:34 +08:00
spdlog@ad0e89cbfb chore: spdlog module 2023-07-07 15:13:23 +08:00
src feat: 发送小程序(待完善) 2023-08-31 08:44:35 +08:00
tool/injector doc: 更新文档 2023-07-08 17:13:38 +08:00
weChatHook-java --user=wxs 增加转发消息功能,可打包成jar直接运行,详情见README.md 2023-06-07 16:34:56 +08:00
.gitignore 3.9.2.23 合并 2023-04-13 15:26:06 +08:00
.gitmodules chore: spdlog module 2023-07-07 15:13:23 +08:00
CMakeLists.txt feat: 3.9.5.81 基础收发功能 2023-06-26 18:23:47 +08:00
LICENSE Create LICENSE 2023-01-10 10:02:56 +08:00
README.md doc: update doc 2023-07-07 14:57:14 +08:00

wxhelper

wechat hook 。PC端微信逆向学习。支持3.8.0.413.8.1.26, 3.9.0.28, 3.9.2.23,3.9.2.26版本。

免责声明:

本仓库发布的内容,仅用于学习研究,请勿用于非法用途和商业用途!如因此产生任何法律纠纷,均与作者无关!

项目说明:

本项目是逆向练习项目,可能会造成封号等后果。请自行承担风险。仅用于学习研究,请勿于非法用途。

实现原理:

逆向分析PC端微信客户端定位相关功能关键Call编写dll调用关键Call。然后将该dll文件注入到微信进程。
dll在注入成功时创建了一个默认端口为19088的http服务端然后所有的功能直接可以通过http协议调用。


                                      |----------------
--------------------------    注入    |  WeChat.exe    |
| ConsoleApplication.exe  |————————>  |----------------           --------------    访问      ---------
|                         |           | wxhelper.dll   |————————>| 启动http服务  | <----------| clent |
|--------------------------           |-----------------          --------------              --------    

使用说明:

支持的版本3.8.0.41、3.8.1.26、3.9.0.28、3.9.2.23、3.9.2.26 、3.9.5.81。
源码和主要实现在相应的分支内。
src:主要的dll代码
tool简单的注入工具一个是控制台一个是图形界面。
python: tcpserver.py: 简单的服务器用以接收消息内容。decrpty.py: 微信数据库解密工具。 http_server.pyhttp server端。
source: 简单的命令行远程注入源码。
其他目录:热心作者提供的一些客户端。

0.首先安装对应的版本的微信分支名称即代表的是微信对应的版本。dll的前缀都会带有微信版本。

1.使用注入工具注入wxhelper.dll,注入成功后即可通过postman直接调用对应的接口。

2.可以使用python/clent.py进行简单测试。

特别注意:
1.hook相关的接口都需要先调用对应的hook接口server端才会收到相应消息。
2.注意个别接口在一些版本没有实现,功能预览里没有的功能就是没有实现。
3.如果注入不成功,请先检查注入工具,或者使用其他注入工具。
4.相关功能只在win11环境下进行简单测试其他环境无法保证。

参与项目

个人精力和水平有限,项目还有许多不足,欢迎提出 issues 或 pr。期待你的贡献。

问题讨论

个人常用的方法,请参考https://github.com/ttttupup/wxhelper/wiki
使用上的问题,可查询https://github.com/ttttupup/wxhelper/discussions
数据库解密,请参考https://github.com/ttttupup/wxhelper/wiki
个人精力有限只维护最新版本旧版本的bug会在新版本中修复不维护旧版本。

编译环境

Visual Studio 2022(x86)

Visual Studio code

cmake

vcpkg

编译构建

先准备好编译环境。

以下是x86环境构建3.9.5.81是x64环境具体参考对应分支。

cd wxhelper  
mkdir build  
cd build  
cmake -DCMAKE_C_COMPILER=cl.exe  \
-DCMAKE_CXX_COMPILER=cl.exe \
-DCMAKE_BUILD_TYPE=Debug \
-DCMAKE_INSTALL_PREFIX=C:/other/codeSource/windows/wxhelper/out/install/x86-debug \
-DCMAKE_TOOLCHAIN_FILE:FILEPATH=C:/vcpkg/scripts/buildsystems/vcpkg.cmake \
-SC:/wxhelper \
-BC:/wxhelper/build/x86-debug\
-G Ninja

cmake --build ..  

以下是在vscode中操作vs中的操作类似。
1.安装vcpkgcmakevscode

2.安装相应的库如果安装的版本不同则根据vcpkg安装成功后提示的find_package修改CMakeLists.txt内容即可。或者自己编译。

    vcpkg  install mongoose  
    vcpkg  install nlohmann-json

3.vscode 配置CMakePresets.json,主要设置CMAKE_C_COMPILER 和CMAKE_CXX_COMPILER 为cl.exe.参考如下

 {
            "name": "x86-release",
            "displayName": "x86-release",
            "description": "Sets Ninja generator, build and install directory",
            "generator": "Ninja",
            "binaryDir": "${sourceDir}/out/build/${presetName}",
            "architecture":{
                "value": "x86",
                "strategy": "external"
            },
            "cacheVariables": {
                "CMAKE_C_COMPILER": "cl.exe",
                "CMAKE_CXX_COMPILER": "cl.exe",
                "CMAKE_BUILD_TYPE": "Release",
                "CMAKE_INSTALL_PREFIX": "${sourceDir}/out/install/${presetName}",
                "CMAKE_TOOLCHAIN_FILE": {
                    "value": "C:/soft/vcpkg/scripts/buildsystems/vcpkg.cmake",
                     "type": "FILEPATH"
                  }
            },
            "environment": {

            }
          
        }

4.执行cmake build vscode中右键configure all projects,在Terminal中点击Run Task如没有先配置build任务然后运行即可

5.命令行注入工具,注入命令

    //-i  注入程序名   -p 注入dll路径   
    // -u 卸载程序名   -d 卸载dll名称
    // -m pid  关闭微信互斥体,多开微信
    // -P port 指定http端口需要使用 specify-port 分支的生成的dll
    // -I 注入程序的pid
    //注入  
    ConsoleInject.exe  -i demo.exe -p E:\testInject.dll
    //卸载 
    ConsoleInject.exe  -u demo.exe -d  testInject.dll
    //多开
    ConsoleInject.exe  -m 1222
    // 注入并指定http端口
    ConsoleInject.exe  -i demo.exe -p E:\testInject.dll  -P  18888   
    // 注入指定pid并关闭多开限制
    ConsoleInject.exe  -I 15048 -p E:\testInject.dll  -m 15048  
  

6.如果想改变端口可以在微信目录下创建config.ini配置文件,修改端口即可。不创建则默认端口19088。

[config]
port=19099

更新说明

2022-12-26 增加3.8.1.26版本支持。

2022-12-29 新增提取文字功能。

2023-01-02 退出微信登录。

2023-01-31 新增修改群昵称仅支持3.8.1.26)。

2023-02-01 新增拍一拍仅支持3.8.1.26)。

2023-02-04 新增群消息置顶和取消置顶。

2023-02-06 新增确认收款。

2023-02-08 新增朋友圈消息。

2023-02-09 新增3.9.0.28版本基础功能。

2023-02-13 新增群昵称和微信名称。

2023-02-17 : 新增通过wxid添加好友,搜索查找微信。

2023-03-02 新增发送@消息

2023-03-04 新增消息附件下载

2023-03-21 新增hook语音

2023-03-30 新增获取语音文件(推荐使用这个非hook接口)

2023-04-08 : 3.9.2.23版本功能更新

2023-06-05 3.9.2.26版本更新

2023-07-07 3.9.5.81版本更新

功能预览:

0.检查是否登录
1.获取登录微信信息
2.发送文本
3.发送@文本
5.发送图片
6.发送文件
9.hook消息
10.取消hook消息
11.hook图片
12.取消hook图片
13.hook语音
14.取消hook语音
17.删除好友
19.通过手机或qq查找微信
20.通过wxid添加好友
23.通过好友申请
25.获取群成员
26.获取群成员昵称
27.删除群成员
28.增加群成员
31.修改群昵称
32.获取数据库句柄
34.查询数据库
35.hook日志
36.取消hook日志
40.转发消息
44.退出登录
45.确认收款
46.联系人列表
47.获取群详情
48.获取解密图片
49.图片提取文字ocr
50.拍一拍
51.群消息置顶消息
52.群消息取消置顶
53.朋友圈首页
54.朋友圈下一页
55.获取联系人或者群名称
56.获取消息附件(图片,视频,文件)
57.获取语音文件(silk3格式)
58.登录二维码
59.邀请入群
60.获取群/群成员详情
61.撤回消息
62.发送公众号消息
63.转发公众号消息
64.发送小程序
65.退款
66.下载头像(勿用,没什么用)

感谢

https://github.com/ljc545w/ComWeChatRobot

https://github.com/NationalSecurityAgency/ghidra

https://github.com/x64dbg/x64dbg

讨论组

https://t.me/+LmvAauweyUpjYzJl