Hook FindWindow

Hook FindWindow

本文关键字:FindWindow Hook      更新时间:2023-10-16

我正在尝试使用Detours 3.0挂接FindWindowA和FindWindowW。这两个函数成功挂钩,我可以看到请求的类和窗口标题。但当我试图访问任何单词时,比如

if ( lpWindowName[0] == buf ) 

或者类似的东西:

wcscpy(buf, lpWindowName);
memcpy(buf, lpWindowName, sizeof(lpWindowName));

我得到错误(exeption在挂钩程序)。我不能访问这个字符串,但我可以使用读取它

MessageBox(NULL,lpWindowName,lpClassName,MB_OK);

http://s017.radikal.ru/i421/1201/73/54fa9046a46c.png我什么都不懂。。。有错误的错误代码。我使用这个代码:

int filter(DWORD code, struct _EXCEPTION_POINTERS *ep) {
    char buf[MAX_PATH] = {0};
    sprintf(buf,"Exception code: %d", code);
    MessageBox(NULL,buf,"Error",MB_OK);
    return EXCEPTION_EXECUTE_HANDLER;
}
HWND __stdcall Mine_FindWindowW(LPCWSTR a0,
    LPCWSTR a1)
{
    __try 
    {
    if (a1[0] == L'a')
        return NULL;
    }
    __except(filter(GetExceptionCode(), GetExceptionInformation())){
    }
    HWND rv = 0;
    __try {
        rv = Real_FindWindowW(a0, a1);
    } __finally {
    };
    return rv;
}

并且绳子没有损坏。所有工作。。。为什么我不能检查或直接访问这两个参数?

检查文档中的FindWindow。

任何一个字符串参数都可以是NULL(意思是不在乎),类名可以是原子。在这两种情况中的任何一种情况下,试图取消引用字符串都会导致访问冲突(异常代码-103741819=0xC0000005)。

您得到的异常是EXCEPTION_ACCESS_VIOLATION(0xC0000005)。看看a1指向的是什么。首先猜测是a1[0]正在进行NULL指针解引用吗?我会在调试器中运行它,并检查调用堆栈以查看坏指针的来源。

你是如何设置Detours的?这可能是一个不正确的迂回的表现。