VC实现搜索IAT HOOK API

 

//
//本程序是用寻找并修改(Improt Address Table)的方法来实现HOOK一个API函数

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

#define   UNICODE
#define   _UNICODE



PIMAGE_DOS_HEADER   pDosHeader;
PIMAGE_NT_HEADERS   pNTHeaders;
PIMAGE_OPTIONAL_HEADER    pOptHeader;
PIMAGE_IMPORT_DESCRIPTOR   pImportDescriptor;
PIMAGE_THUNK_DATA          pThunkData;
PIMAGE_IMPORT_BY_NAME      pImportByName;
HMODULE hMod;

int * addr = (int *)MessageBoxA;         //保存函数的入口地址
// 定义MessageBoxA函数原型
typedef int (WINAPI *PFNMESSAGEBOX)(HWND, LPCSTR, LPCSTR, UINT uType);
int WINAPI MessageBoxProxy(IN HWND hWnd, IN LPCSTR lpText, IN LPCSTR lpCaption, IN UINT uType);

int * myaddr = (int *)MessageBoxProxy;

int main()
{
         //OutputDebugString(_T("start !"));
         MessageBoxA(NULL, "原函数", "09HookDemo", 0);

         //-------------HOOK部分
         hMod = GetModuleHandle(NULL);

         pDosHeader = (PIMAGE_DOS_HEADER)hMod;
         pNTHeaders = (PIMAGE_NT_HEADERS)((BYTE *)hMod + pDosHeader->e_lfanew);
         pOptHeader = (PIMAGE_OPTIONAL_HEADER)&(pNTHeaders->OptionalHeader);

         pImportDescriptor = (PIMAGE_IMPORT_DESCRIPTOR)((BYTE *)hMod + pOptHeader->DataDirectory[1].VirtualAddress);

         while(pImportDescriptor->FirstThunk)
         {
                 char * dllname = (char *)((BYTE *)hMod + pImportDescriptor->Name);
                 //printf("函数模块:%s\n",dllname);

                 pThunkData = (PIMAGE_THUNK_DATA)((BYTE *)hMod + pImportDescriptor->OriginalFirstThunk);

                 int no = 1;
                 while(pThunkData->u1.Function)
                 {
                         char * funname = (char *)((BYTE *)hMod + (DWORD)pThunkData->u1.AddressOfData + 2);
                         PDWORD lpAddr = (DWORD *)((BYTE *)hMod + (DWORD)pImportDescriptor->FirstThunk) +(no-1);
                        
                         //printf("%4d:   ",no);
                         //printf("%30s",funname);
                         //printf("%8x\n",lpAddr);
                         //printf("%8x\n",*lpAddr);
                         //修改内存的部分
                         if((*lpAddr) == (int)addr)
                         {
                                 //修改内存页的属性
                                 DWORD dwOLD;
                                 MEMORY_BASIC_INFORMATION   mbi;
                                 VirtualQuery(lpAddr,&mbi,sizeof(mbi));
                                 VirtualProtect(lpAddr,sizeof(DWORD),PAGE_READWRITE,&dwOLD);
                                 //写内存
                                 WriteProcessMemory(GetCurrentProcess(),
                                                 lpAddr, &myaddr, sizeof(DWORD), NULL);
                                 //恢复内存页的属性
                                 VirtualProtect(lpAddr,sizeof(DWORD),dwOLD,0);
                         }
             //---------
                         no++;
                         pThunkData++;
                 }

                 pImportDescriptor++;
         }

         //用于测试的API函数
         MessageBoxA(NULL, "原函数", "09HookDemo", 0);

         getchar();
         return 0;
}

int WINAPI MessageBoxProxy(IN HWND hWnd, IN LPCSTR lpText, IN LPCSTR lpCaption, IN UINT uType)
{
         return          ((PFNMESSAGEBOX)addr)(NULL, "Gxter", "Gxter", 0);
         //用地址调用一个API函数
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值