欢迎关注技术公众号:汉客儿
QQ交流群:753894145
1. 目前项目已经支持防消息撤回,细节请看文章
2. 支持语音消息备份,细节请看文章
3. 支持发送消息接口,细节请看文章
4. 目前发布WeChatSDK,第三方可以应用SDK开发自己的软件,详细请看文章
5. 项目一直持续更新,跟进微信发布的新版本,欢迎关注公众号汉客儿获取最新信息
6. 项目地址:https://github.com/anhkgg/SuperWeChatPC
7. 最新版可用多开软件exe可再公众号后台回复”微信多开”获得下载链接。
0x00 前言
不知道大家有没有多个微信号,我反正有一两三个。
现在电脑端微信使用频率也比较高,主要用于大文件传输,或者手机电脑文件互传等等,除了不能收红包和看朋友圈,貌似电脑端没其他毛病。
哦,还有个毛病,只能开一个微信,只能开一个,开一个,一个…
不管这些有的没的,今天的主题是,怎么样在电脑上开多个微信客户端!
0x01 分析
了解过单实例的同学,应该都知道大概是怎么实现的单开。
简单说下,大都通过判断Mutex、Event、File等等是否已经存在,存在则退出当前开启进程(说明已经有一个进程了),这样也就是单实例了。
那只要找到微信是通过什么标志来实现单实例的,然后干掉这个标志即可。
然后…基于这个思路,我们上工具。
使用procexp找到微信进程,然后翻了一遍句柄。
找到疑是的一段句柄。
1 | \Sessions\1\BaseNamedObjects\_WeChat_App_Instance_Identity_Mutex_Name |
感觉这两个都像,不管了,上pchunter,kill掉句柄试一下。
经过尝试,发现_WeChat_App_Instance_Identity_Mutex_Name
是单实例标志(kill句柄后可以开第二个客户端),WeChat_GlobalConfig_Multi_Process_Mutex
没用。
既然如此,那开始码代码吧。
0x02 代码
可能的方案:
- 找微信判断标识的代码位置,然后直接patch掉,或者整个dll进去patch。然后大致去翻了一下,貌似代码在wechatwin.dll,然后加了vmp壳,所以就不折腾这个了。
- 直接通过代码kill掉这个Mutex的句柄(类似Pchunter操作),然后就可以开启第二个实例了,貌似明显更有优势啊。
- 额,如果觉得无所谓,每次开之前用pchunter关一次句柄也行,下面就不用看了…
这里选择第二个方案,开始代码。
流程:
- 枚举句柄,找到_WeChat_App_Instance_Identity_Mutex_Name的mutant
- duplicate句柄到本进程,然后close
- 启动微信
下面是主要代码:
1 | //步骤1和2的代码 |
1 | 步骤3的代码 |
代码就这样,有注释,就不再啰嗦。
完整代码,请看后面的地址。
0x03 总结
一个小玩意,供大家一笑。
编译好的可执行文件:
https://github.com/anhkgg/multi_wechat_pc/raw/master/WeChat%E5%A4%9A%E5%BC%80.exe
源码地址:
https://github.com/anhkgg/multi_wechat_pc
博客原文: