如何获取其它进程中窗口的窗口过程

获取其他进程窗口的窗口过程并非易事,因为GetWindowLong函数会检查调用进程和窗口是否在同一进程。本文介绍了如何通过创建远程线程,模拟在目标进程中执行GetWindowLong以获取窗口过程。首先,通过GetWindowThreadProcessId和OpenProcess获取目标进程信息,然后在远程进程中分配内存并写入汇编代码实现GetWindowLong和PostThreadMessage功能,最后创建远程线程执行这段代码,通过消息循环接收返回结果。
摘要由CSDN通过智能技术生成
 如何获取其它进程中窗口的窗口过程
helloworld 发表于:2008-9-29 14:52:00   阅读数:9


如何获取其它进程中窗口的窗口过程

作者:耿海增

下载源代码

开发环境: Windows XP + VC6+Platform SDK 或者 VS.NET 2003+
测试环境: Windows XP

  曾经以为获取一个窗口的窗口过程很简单,不就是GetWindowLong一下吗,看spyxx获取的多么顺利。后来才发现原来不是这么简单。获取本进程内窗口的窗口过程确实很简单 ,直接调用GetWindowLong(hWnd,GWL_WNDPROC)就可以了(注意,根据窗口是否是Unicode的,你要判断是调用GetWindowLongA,还是GetWindowLongW,可以用IsWindowUnicode来判断), 但是GetWindowLong这个函数内部会检查调用进程和该窗口句柄是否属于同一进程,如果不是,就简单的返回0了。
  既然这样,我们又不能去修改GetWindowLong,那就只有想办法让它认为我们和那个窗口是在一个进程里了。回想起Windows核心编程里讲过,通过创建远程线程的方式 ,可以在其它进程内创建一个新的线程,并且可以指定这个线程的线程函数 。因为Windows的进程之间的地址相互之间是不可

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
获取进程窗口界面句柄可以通过以下步骤实现: 1. 使用进程的ID获取进程句柄,可以使用函数OpenProcess()。 2. 使用函数EnumWindows()枚举所有的顶层窗口获取每个窗口进程ID,使用函数GetWindowThreadProcessId()。 3. 比对每个窗口进程ID是否与目标进程的ID匹配,如果匹配则说明该窗口属于目标进程。 4. 使用函数IsWindowVisible()判断该窗口是否可见。 5. 如果窗口可见,则说明该窗口是目标进程的主窗口,可以使用该窗口的句柄作为进程窗口界面句柄。 以下是示例代码: ``` DWORD dwProcessId = ...; // 目标进程的ID // 获取目标进程的句柄 HANDLE hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, dwProcessId); if (hProcess == NULL) { // 处理错误 return; } // 枚举所有窗口 HWND hWnd = NULL; while ((hWnd = FindWindowEx(NULL, hWnd, NULL, NULL)) != NULL) { // 获取窗口所属进程的ID DWORD dwThreadId = GetWindowThreadProcessId(hWnd, NULL); if (dwThreadId == 0) { // 处理错误 continue; } DWORD dwWindowProcessId = GetProcessIdOfThread(OpenThread(THREAD_QUERY_INFORMATION, FALSE, dwThreadId)); if (dwWindowProcessId == 0) { // 处理错误 continue; } if (dwWindowProcessId != dwProcessId) { // 不是目标进程窗口,继续枚举 continue; } // 判断窗口是否可见 if (!IsWindowVisible(hWnd)) { // 窗口不可见,继续枚举 continue; } // 该窗口是目标进程的主窗口,作为进程窗口界面句柄 HWND hProcessWindow = hWnd; break; } // 关闭目标进程的句柄 CloseHandle(hProcess); ``` 注意:如果目标进程有多个窗口,则该方法只能获取到其一个窗口的句柄,需要根据实际情况选择。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值