WeChats.cpp 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. // WeChats.cpp : 定义应用程序的类行为。
  2. //
  3. #include "stdafx.h"
  4. #include "WeChats.h"
  5. #include "WeChatsDlg.h"
  6. #include "Injection.h"
  7. #ifdef _DEBUG
  8. #define new DEBUG_NEW
  9. #endif
  10. // CWeChatsApp
  11. BEGIN_MESSAGE_MAP(CWeChatsApp, CWinAppEx)
  12. ON_COMMAND(ID_HELP, &CWinApp::OnHelp)
  13. END_MESSAGE_MAP()
  14. // CWeChatsApp 构造
  15. CWeChatsApp::CWeChatsApp()
  16. {
  17. // TODO: 在此处添加构造代码,
  18. // 将所有重要的初始化放置在 InitInstance 中
  19. }
  20. // 唯一的一个 CWeChatsApp 对象
  21. CWeChatsApp theApp;
  22. // CWeChatsApp 初始化
  23. BOOL CWeChatsApp::InitInstance()
  24. {
  25. // 如果一个运行在 Windows XP 上的应用程序清单指定要
  26. // 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
  27. //则需要 InitCommonControlsEx()。否则,将无法创建窗口。
  28. INITCOMMONCONTROLSEX InitCtrls;
  29. InitCtrls.dwSize = sizeof(InitCtrls);
  30. // 将它设置为包括所有要在应用程序中使用的
  31. // 公共控件类。
  32. InitCtrls.dwICC = ICC_WIN95_CLASSES;
  33. InitCommonControlsEx(&InitCtrls);
  34. CWinAppEx::InitInstance();
  35. AfxEnableControlContainer();
  36. // 获取配置信息;
  37. GetIniInfo();
  38. GetDebugPriv();
  39. #if _DEBUG // 创建进程,并挂起;
  40. STARTUPINFO si;
  41. PROCESS_INFORMATION pi;
  42. ZeroMemory(&si, sizeof(si));
  43. si.cb = sizeof(si);
  44. ZeroMemory(&pi, sizeof(pi));
  45. si.dwFlags = STARTF_USESHOWWINDOW; // 指定wShowWindow成员有效
  46. si.wShowWindow = TRUE; // 此成员设为TRUE的话则显示新建进程的主窗口,
  47. // 为FALSE的话则不显示
  48. BOOL bRet = ::CreateProcess (
  49. _T("C:\\Program Files (x86)\\Tencent\\WeChat\\WeChat.exe"), // 不在此指定可执行文件的文件名
  50. NULL, // 命令行参数
  51. NULL, // 默认进程安全性
  52. NULL, // 默认线程安全性
  53. FALSE, // 指定当前进程内的句柄不可以被子进程继承
  54. CREATE_SUSPENDED, // 挂起进程;
  55. NULL, // 使用本进程的环境变量
  56. NULL, // 使用本进程的驱动器和目录
  57. &si,
  58. &pi);
  59. if(bRet)
  60. {
  61. // 进程挂起后,仍能成功注入dll;
  62. TCHAR szDllPath[MAX_PATH];
  63. ZeroMemory(szDllPath,MAX_PATH);
  64. _stprintf_s(szDllPath, _T("%shook.dll"), g_szModulePath);
  65. for (int i = 0; i < 10; i++)
  66. {
  67. CInjection inject(pi.dwProcessId,szDllPath);
  68. inject.InjectDynamicLibrary();
  69. inject.EjectDynamicLibrary();
  70. Sleep(3000);
  71. }
  72. //不sleep就会出现读取不到的297错误
  73. Sleep(5000);
  74. //获取线程上下文
  75. CONTEXT ct = { 0 };
  76. ct.ContextFlags = CONTEXT_CONTROL;
  77. GetThreadContext(pi.hThread, &ct);
  78. ::ResumeThread(pi.hThread);
  79. // 既然我们不使用两个句柄,最好是立刻将它们关闭
  80. ::CloseHandle (pi.hThread);
  81. ::CloseHandle (pi.hProcess);
  82. }
  83. #endif
  84. #if !_DEBUG
  85. TCHAR szDllPath[MAX_PATH];
  86. ZeroMemory(szDllPath,MAX_PATH);
  87. DWORD ss = sizeof(szDllPath);
  88. DWORD sss = _tcslen(szDllPath)*sizeof(TCHAR);
  89. _stprintf_s(szDllPath, _T("%shook.dll"), g_szModulePath);
  90. vector<DWORD> vtPID = FindAllProcess(WECHAT);
  91. if (vtPID.size() != 0 )
  92. {
  93. for (int i = 0; i < 100; i++)
  94. {
  95. CInjection inject(*vtPID.begin(),szDllPath);
  96. inject.InjectDynamicLibrary();
  97. inject.EjectDynamicLibrary();
  98. Sleep(3000);
  99. }
  100. }
  101. #endif
  102. // 标准初始化
  103. // 如果未使用这些功能并希望减小
  104. // 最终可执行文件的大小,则应移除下列
  105. // 不需要的特定初始化例程
  106. // 更改用于存储设置的注册表项
  107. // TODO: 应适当修改该字符串,
  108. // 例如修改为公司或组织名
  109. SetRegistryKey(_T("应用程序向导生成的本地应用程序"));
  110. CWeChatsDlg dlg;
  111. m_pMainWnd = &dlg;
  112. INT_PTR nResponse = dlg.DoModal();
  113. if (nResponse == IDOK)
  114. {
  115. // TODO: 在此放置处理何时用
  116. // “确定”来关闭对话框的代码
  117. }
  118. else if (nResponse == IDCANCEL)
  119. {
  120. // TODO: 在此放置处理何时用
  121. // “取消”来关闭对话框的代码
  122. }
  123. // 由于对话框已关闭,所以将返回 FALSE 以便退出应用程序,
  124. // 而不是启动应用程序的消息泵。
  125. return FALSE;
  126. }