日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

第九章 hook windows程序设计 王艳平版

發布時間:2023/12/29 windows 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 第九章 hook windows程序设计 王艳平版 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

// 09HookDemo.cpp文件






#include <windows.h>
#include <stdio.h>


// 掛鉤指定模塊hMod對MessageBoxA的調用
BOOL SetHook(HMODULE hMod);
// 定義MessageBoxA函數原型
typedef int (WINAPI *PFNMESSAGEBOX)(HWND, LPCSTR, LPCSTR, UINT uType);
// 保存MessageBoxA函數的真實地址
PROC g_orgProc = (PROC)MessageBoxA;


void main()
{
// 調用原API函數
::MessageBox(NULL, "原函數", "09HookDemo", 0);
// 掛鉤后再調用
SetHook(::GetModuleHandle(NULL));
::MessageBox(NULL, "原函數", "09HookDemo", 0);
}


// 用于替換MessageBoxA的自定義函數
int WINAPI MyMessageBoxA(HWND hWnd, LPCSTR lpText, LPCSTR lpCaption, UINT uType)
{
return ((PFNMESSAGEBOX)g_orgProc)(hWnd, "新函數", "09HookDemo", uType);
}


BOOL SetHook(HMODULE hMod)
{
IMAGE_DOS_HEADER* pDosHeader = (IMAGE_DOS_HEADER*)hMod;
IMAGE_OPTIONAL_HEADER * pOptHeader =
(IMAGE_OPTIONAL_HEADER *)((BYTE*)hMod + pDosHeader->e_lfanew + 24);

IMAGE_IMPORT_DESCRIPTOR* pImportDesc = (IMAGE_IMPORT_DESCRIPTOR*)
((BYTE*)hMod + pOptHeader->DataDirectory[IMAGE_DIRECTORY_ENTRY_IMPORT].VirtualAddress);

// 在導入表中查找user32.dll模塊。因為MessageBoxA函數從user32.dll模塊導出
while(pImportDesc->FirstThunk)
{
char* pszDllName = (char*)((BYTE*)hMod + pImportDesc->Name);
if(lstrcmpiA(pszDllName, "user32.dll") == 0)
{
break;
}
pImportDesc++;
}


if(pImportDesc->FirstThunk)
{

// 一個IMAGE_THUNK_DATA就是一個雙字,它指定了一個導入函數
// 調入地址表其實是IMAGE_THUNK_DATA結構的數組,也就是DWORD數組
IMAGE_THUNK_DATA* pThunk = (IMAGE_THUNK_DATA*)
((BYTE*)hMod + pImportDesc->FirstThunk);
while(pThunk->u1.Function)
{
// lpAddr指向的內存保存了函數的地址
DWORD* lpAddr = (DWORD*)&(pThunk->u1.Function);
if(*lpAddr == (DWORD)g_orgProc)
{
// 修改IAT表項,使其指向我們自定義的函數,相當于“*lpAddr = (DWORD)MyMessageBoxA;”
DWORD* lpNewProc = (DWORD*)MyMessageBoxA;
::WriteProcessMemory(::GetCurrentProcess(),?
lpAddr, &lpNewProc, sizeof(DWORD), NULL);
return TRUE;
}

pThunk++;
}
}
return FALSE;
}



總結

以上是生活随笔為你收集整理的第九章 hook windows程序设计 王艳平版的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。