gpt4 book ai didi

c++ - 为什么C++中的API hook ExtTextOut和DrawText只会输出垃圾?

转载 作者:行者123 更新时间:2023-11-28 03:15:29 25 4
gpt4 key购买 nike

我正在尝试使用 Detour 创建一个 API Hook ,以从第三方程序中提取文本输出。然而,我只得到垃圾,很多数字,没有文本输出。

具体什么时候调用这些函数?他们是否也被要求绘制除文字以外的其他东西?如果第三方程序使用一些高级工具来避免拦截这些调用,是否有一些基本示例可以尝试确保我的方法确实正确接收文本?换句话说,windows中是否有一些程序使用这些方法在屏幕上绘制文本?

我的代码如下:

BOOL (__stdcall *Real_ExtTextOut)(HDC hdc,int x, int y, UINT options, const RECT* lprc,LPCWSTR text,UINT cbCount, const INT* lpSpacingValues) = ExtTextOut;
BOOL (__stdcall *Real_DrawText)(HDC hdc, LPCWSTR text, int nCount, LPRECT lpRect, UINT uOptions) = DrawText;

int WINAPI Mine_DrawText(HDC hdc, LPCWSTR text, int nCount, LPRECT lpRect, UINT uOptions)
{
ofstream myFile;
myFile.open ("C:\\temp\\textHooking\\textHook\\example.txt", ios::app);
for(int i = 0; i < nCount; ++i)
myFile << text[i];
myFile << endl;
int rv = Real_DrawText(hdc, text, nCount, lpRect, uOptions);

return rv;
}

BOOL WINAPI Mine_ExtTextOut(HDC hdc, int X, int Y, UINT options, RECT* lprc, LPCWSTR text, UINT cbCount, INT* lpSpacingValues)
{
ofstream myFile;
myFile.open ("C:\\temp\\textHooking\\textHook\\example2.txt", ios::app);
for(int i = 0; i < cbCount; ++i)
myFile << text[i];
myFile << endl;
BOOL rv = Real_ExtTextOut(hdc, X, Y, options, lprc, text, cbCount, lpSpacingValues);

return rv;
}

// Install the DrawText detour whenever this DLL is loaded into any process
BOOL APIENTRY DllMain( HMODULE hModule, DWORD ul_reason_for_call, LPVOID lpReserved){
switch (ul_reason_for_call)
{
case DLL_PROCESS_ATTACH:
DetourTransactionBegin();
DetourUpdateThread(GetCurrentThread());
DetourAttach(&(PVOID&)Real_ExtTextOut, Mine_ExtTextOut);
DetourAttach(&(PVOID&)Real_DrawText, Mine_DrawText);
DetourTransactionCommit();
case DLL_THREAD_ATTACH:
case DLL_THREAD_DETACH:
case DLL_PROCESS_DETACH:
break;
}

return TRUE;
}

最佳答案

您正在将 UTF-16 字符代码写为整数。因此文件中充满了数字。将文本缓冲区直接 blit 到文件可能更容易:

ofstream myFile;
myFile.open("C:\\temp\\textHooking\\textHook\\example.txt", ios::app);
myFile.write(reinterpret_cast<const char*>text, nCount*sizeof(*text));
myFile << endl;

您可能希望将 UTF-16LE BOM 放在文件的前面,以帮助您的文本编辑器计算出正在使用的编码。

关于c++ - 为什么C++中的API hook ExtTextOut和DrawText只会输出垃圾?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17032077/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com