zoukankan      html  css  js  c++  java
  • PC微信(WeChat)电脑端多开分析+源码

    0x00 前言

    不知道大家有没有多个微信号,我反正有一两三个。

    现在电脑端微信使用频率也比较高,主要用于大文件传输,或者手机电脑文件互传等等,除了不能收红包和看朋友圈,貌似电脑端没其他毛病。

    哦,还有个毛病,只能开一个微信,只能开一个,开一个,一个…

    不管这些有的没的,今天的主题是,怎么样在电脑上开多个微信客户端!

    0x01 分析

    了解过单实例的同学,应该都知道大概是怎么实现的单开。

    简单说下,大都通过判断Mutex、Event、File等等是否已经存在,存在则退出当前开启进程(说明已经有一个进程了),这样也就是单实例了。

    那只要找到微信是通过什么标志来实现单实例的,然后干掉这个标志即可。

    然后…基于这个思路,我们上工具。

    使用procexp找到微信进程,然后翻了一遍句柄。

    找到疑是的一段句柄。

    这里写图片描述

    Sessions1BaseNamedObjects\_WeChat_App_Instance_Identity_Mutex_Name
    Sessions1BaseNamedObjectsWeChat_GlobalConfig_Multi_Process_Mutex
    • 1
    • 2

    感觉这两个都像,不管了,上pchunter,kill掉句柄试一下。

    经过尝试,发现_WeChat_App_Instance_Identity_Mutex_Name是单实例标志(kill句柄后可以开第二个客户端),WeChat_GlobalConfig_Multi_Process_Mutex没用。

    既然如此,那开始码代码吧。

    0x02 代码

    可能的方案:

    1. 找微信判断标识的代码位置,然后直接patch掉,或者整个dll进去patch。然后大致去翻了一下,貌似代码在wechatwin.dll,然后加了vmp壳,所以就不折腾这个了。
    2. 直接通过代码kill掉这个Mutex的句柄(类似Pchunter操作),然后就可以开启第二个实例了,貌似明显更有优势啊。
    3. 额,如果觉得无所谓,每次开之前用pchunter关一次句柄也行,下面就不用看了…

    这里选择第二个方案,开始代码。

    流程: 
    1. 枚举句柄,找到_WeChat_App_Instance_Identity_Mutex_Name的mutant 
    2. duplicate句柄到本进程,然后close 
    3. 启动微信

    下面是主要代码:

    //步骤1和2的代码
    //获取到微信所有进程句柄
    DWORD Num = GetProcIds(L"WeChat.exe", Pids);
    ...
    
    Status = ZwQuerySystemInformation(SystemHandleInformation, pbuffer, 0x1000, &dwSize);
    
    PSYSTEM_HANDLE_INFORMATION1 pHandleInfo = (PSYSTEM_HANDLE_INFORMATION1)pbuffer;
    
        for(nIndex = 0; nIndex < pHandleInfo->NumberOfHandles; nIndex++)
        {
            //句柄在Pids中,就是微信进程的句柄信息
            if(IsTargetPid(pHandleInfo->Handles[nIndex].UniqueProcessId, Pids, Num))
            {
                HANDLE hHandle = DuplicateHandleEx(pHandleInfo->Handles[nIndex].UniqueProcessId, 
                            (HANDLE)pHandleInfo->Handles[nIndex].HandleValue,
                            DUPLICATE_SAME_ACCESS
                            );
    
                //对象名
                Status = NtQueryObject(hHandle, ObjectNameInformation, szName, 512, &dwFlags);
                //对象类型名
                Status = NtQueryObject(hHandle,  ObjectTypeInformation, szType, 128, &dwFlags);
    
                //找到微信的标志
                if (0 == wcscmp(TypName, L"Mutant"))
                {
                    if (wcsstr(Name, L"_WeChat_App_Instance_Identity_Mutex_Name"))
                    {
    
                        //DUPLICATE_CLOSE_SOURCE标志很重要,不明白的查一查
                        hHandle = DuplicateHandleEx(pHandleInfo->Handles[nIndex].UniqueProcessId, 
                            (HANDLE)pHandleInfo->Handles[nIndex].HandleValue,
                            DUPLICATE_CLOSE_SOURCE
                            );
                        if(hHandle)
                        {
                            printf("+ Patch wechat success!
    ");
                            CloseHandle(hHandle);
                        }
                    }
                }
            }
    
        }
    }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    步骤3的代码
    
    //通过注册表找到微信安装目录
    if(ERROR_SUCCESS != RegOpenKey(HKEY_CURRENT_USER, L"Software\Tencent\WeChat", &hKey))
    {
        return;
    }
    
    DWORD Type = REG_SZ;
    WCHAR Path[MAX_PATH] = {0};
    DWORD cbData = MAX_PATH*sizeof(WCHAR);
    if(ERROR_SUCCESS != RegQueryValueEx(hKey, L"InstallPath", 0, &Type, (LPBYTE)Path, &cbData))
    {
        goto __exit;
    }
    
    PathAppend(Path, L"WeChat.exe");
    
    //启动微信客户端
    ShellExecute(NULL, L"Open", Path, NULL, NULL, SW_SHOW);
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    代码就这样,有注释,就不再啰嗦。

    完整代码,请看后面的地址。

    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

  • 相关阅读:
    抽象工厂
    MVC模型验证+客户端验证
    模型绑定
    Linq 构建块
    Linq的简单应用_01
    简单的Jquery轮播
    实现自己的代码生成器
    JS练习--闭包
    node部署网页
    IE8-浏览器下iframe的动态onload事件处理
  • 原文地址:https://www.cnblogs.com/ChiYue/p/8964891.html
Copyright © 2011-2022 走看看