windows客户端开发,最烦就是句柄了,有了句柄,其他人就可以向你发消息。
所以这个时候,需要使用下GetWindowLong。
1 GetWindowLong是一个Windows API函数。该函数获得指定窗口的有关信息,函数也获得在额外窗口内存中指定偏移位地址的32位度整型值。
LONG GetWindowLong(HWND hWnd,int nlndex);
nlndex
需要获得的相关信息的类型。
GWL_WNDPROC (-4) |
获得窗口过程的地址,或代表窗口过程的地址的句柄。必须使用CallWindowProc函数调用窗口过程。 |
窗口过程:就是处理消息的地方。这个函数可以在跨进程使用。
2 SetWindowLong是一个Windows API函数。该函数用来改变指定窗口的属性.函数也将指定的一个32位值设置在窗口的额外存储空间的指定偏移位置。
1 2 3 4 5 |
|
nlndex
指定将设定的大于等于0的偏移值。
GWL_WNDPROC |
-4 |
为窗口过程设定一个新的地址。 |
如果由hWnd参数指定的窗口与调用线程不属于同一进程,将导致SetWindowLong函数修改窗口过程失败。
如果进程注入,就要注意了。
3 所以可以先GetWindowLong获得老的窗口处理函数,然后通过SetWindowLong在拦截消息后,再发给老处理函数处理。
时间: 2024-11-08 08:00:54