欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Inline Hook(ring3)的簡單C++實現(xiàn)方法

 更新時間:2014年08月11日 09:32:41   投稿:shichen2014  
這篇文章主要介紹了Inline Hook(ring3)的簡單C++實現(xiàn)方法,需要的朋友可以參考下

C++的Inline Hook代碼,采用了備份dll的方法,因此在自定義的函數(shù)中可以直接調(diào)用在內(nèi)存中備份的dll代碼,而不需要把函數(shù)頭部改來改去。用SetWindowsHookEx程序的穩(wěn)定性應該會增加許多。

需要注意的是,例子中沒有把原函數(shù)的頭部幾個字節(jié)改回去是因為,程序很簡單,僅僅測試了效果后便可以退出,沒有其他的功能。實際應用中,還要在你注入的dll模塊卸載時,把原函數(shù)的頭幾個字節(jié)改回去,以免影響到程序繼續(xù)運行的穩(wěn)定性。(因為注入的程序不是自己的,我們當然不可能知道它到底在何時、有多少個我們所Hook的函數(shù)的調(diào)用)。

具體實現(xiàn)代碼如下:

#include <ntifs.h>
#include <windef.h> 
#include <stdio.h>
#pragma comment(lib, "psapi.lib")
//BYTE Org_Code[7];// 備份dll法, 因此就可以不需要
BYTE New_Code[7];
HMODULE hDllHandle = NULL; // 被 Hook 的 DLL 句柄
HANDLE hProcess = NULL; // 進程句柄
LPVOID _MessageBoxA = NULL; // MessageBoxA() 原地址
DWORD _ShowMessage = NULL; // 自定義函數(shù)地址
void InlineHook();
//void UnInlineHook(); // 備份dll法, 因此就可以不需要
void BackupDll();
// 自定義函數(shù)
int WINAPI ShowMessage(HWND, LPTSTR, LPTSTR, UINT);
void main()
{
  hProcess = ::GetCurrentProcess();
  hDllHandle = ::LoadLibrary("user32.dll");
  if (hDllHandle == NULL)
    return;
  _MessageBoxA = (LPVOID)::GetProcAddress(hDllHandle, "MessageBoxA");
  if (_MessageBoxA == NULL)
    return;
  BackupDll();
  InlineHook();
  char szText[256];
  char szTitle[256];
  memset(szText, 0x0, sizeof(szText));
  memset(szTitle, 0x0, sizeof(szTitle));
  // 下列循環(huán)接收來自于用戶輸入的字符, 并使用 MessageBoxA()
  //來顯示, 嘗試下, 看看發(fā)生了什么. :)
  while (TRUE)
  {
    printf("Message Text: ");
    scanf("%s", szText);
    printf("Message Title: ");
    scanf("%s", szTitle);
    MessageBoxA(NULL, szText, szTitle, 0);
    printf("\n");
  }
  return;
}
void InlineHook()
{
  DWORD _JmpAddr = (DWORD)ShowMessage;
  // 構造新頭部代碼
  New_Code[0] = 0xB8;            //
  memcpy(&New_Code[1], &_JmpAddr, 4);    // mov eax, _JmpAddr
  New_Code[5] = 0xFF;            //
  New_Code[6] = 0xE0;            // jmp eax
  DWORD dwOldProtect = 0;
  // 去內(nèi)存保護
  ::VirtualProtect(_MessageBoxA, 7, PAGE_EXECUTE_READWRITE, &dwOldProtect);
  // 把新代碼寫入 MessageBoxA() 的頭部, 這也是Inline Hook
  //的核心所在.
  ::WriteProcessMemory(
    hProcess,
    _MessageBoxA,
    New_Code,
    sizeof(New_Code),
    NULL
  );
  // 寫內(nèi)存保護
  ::VirtualProtect(_MessageBoxA, 7, dwOldProtect, &dwOldProtect);
  return;
}
/*
void UnInlineHook() // 備份dll法, 因此就可以不需要
{
  return;
}
*/
int WINAPI ShowMessage(HWND hWnd, LPTSTR lpText, LPTSTR lpTitle, UINT uType)
{
  typedef int WINAPI SHOWMSG(HWND hWnd, LPTSTR lpText, LPTSTR lpTitle, UINT uType);
  SHOWMSG *pShowMsg = (SHOWMSG*)_ShowMessage;
  // 廢棄原先傳入的參數(shù), 自己定義對話框文本
  char buf[1024];
  ::wsprintf(buf, "The Text:"%s" was hacked by miku_fl", lpText);
  return pShowMsg(hWnd, buf, lpTitle, MB_ICONINFORMATION | MB_TOPMOST);
}
void BackupDll()
{
  MODULEINFO  Mdl_Info;
  LPVOID    lpNewDLL  =  NULL;
  // 獲取模塊信息
  ::GetModuleInformation(hProcess, hDllHandle, &Mdl_Info, sizeof(Mdl_Info));
  // 分配內(nèi)存空間, 用于備份 dll (這樣一來就不需要恢復原頭部代碼, 調(diào)用
  //完之后再重新寫自定義的頭部代碼).
  lpNewDLL = ::VirtualAllocEx(
    hProcess,
    NULL,
    Mdl_Info.SizeOfImage,
    MEM_COMMIT,
    PAGE_EXECUTE_READWRITE
  );
  if (lpNewDLL == NULL)
    return;
  // 在分配的內(nèi)存中寫入 dll 文件的內(nèi)容
  ::WriteProcessMemory(hProcess, lpNewDLL, Mdl_Info.lpBaseOfDll, Mdl_Info.SizeOfImage, NULL);
  // 計算自定義函數(shù)的地址.
  // 公式: 自定義地址 = 原API函數(shù)地址 - 模塊基址 + 分配內(nèi)存的基址
  _ShowMessage = (DWORD)_MessageBoxA - (DWORD)Mdl_Info.lpBaseOfDll + (DWORD)lpNewDLL;
  return;
}

希望本文所述程序實例能對大家有所幫助。

相關文章

  • C語言實現(xiàn)火車訂票系統(tǒng)

    C語言實現(xiàn)火車訂票系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)火車訂票系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 十進制與BCD碼轉換的算法詳解

    十進制與BCD碼轉換的算法詳解

    BCD轉換成十進制 BCD碼是指用二進制來表示十進制數(shù)的編碼,即用4位二進制來表示一位十進制數(shù),因此4位二進制數(shù)表示最大的十進制數(shù)9(1001),只取十六個數(shù)中的十個數(shù)(有別于8421碼)
    2021-09-09
  • 帶你深度走入C語言取整以及4種函數(shù)

    帶你深度走入C語言取整以及4種函數(shù)

    大家都知道取整這回事,但是對于取整只有單一的認識,下面這篇文章主要給大家介紹了關于C語言取整以及4種函數(shù)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • C++實現(xiàn)職工信息管理系統(tǒng)

    C++實現(xiàn)職工信息管理系統(tǒng)

    這篇文章主要為大家詳細介紹了c++實現(xiàn)職工信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 深入解析C++和JAVA的字符串

    深入解析C++和JAVA的字符串

    這篇文章主要介紹了C++和JAVA的字符串,JAVA 中String 和StringBuffer的區(qū)別,需要的朋友可以參考下
    2015-07-07
  • c++實現(xiàn)排序算法之希爾排序方式

    c++實現(xiàn)排序算法之希爾排序方式

    這篇文章主要介紹了c++實現(xiàn)排序算法之希爾排序方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • wince禁止程序標題欄上的退出按鈕示例

    wince禁止程序標題欄上的退出按鈕示例

    這篇文章主要介紹了wince禁止程序標題欄上的退出按鈕示例,需要的朋友可以參考下
    2014-02-02
  • 淺談C語言中include

    淺談C語言中include""與include<>的區(qū)別

    C語言中包含文件有兩種包含符號,一個是<>尖括號,另一個是""雙引號。那么這兩個有什么區(qū)別呢?本文就詳細的介紹一下,感興趣的可以了解一下
    2021-06-06
  • 關于C++靜態(tài)成員函數(shù)訪問非靜態(tài)成員變量的問題

    關于C++靜態(tài)成員函數(shù)訪問非靜態(tài)成員變量的問題

    靜態(tài)成員函數(shù)不能訪問非靜態(tài)成員,這是因為靜態(tài)函數(shù)屬于類而不是屬于整個對象,靜態(tài)函數(shù)中的 member可能都沒有分配內(nèi)存。靜態(tài)成員函數(shù)沒有隱含的this自變量。所以,它就無法訪問自己類的非靜態(tài)成員
    2013-10-10
  • C語言中枚舉與聯(lián)合體的使用方法(enum union)

    C語言中枚舉與聯(lián)合體的使用方法(enum union)

    枚舉的意思就是列舉,將每一個可能的取值都進行一一列舉,下面這篇文章主要給大家介紹了關于C語言中枚舉與聯(lián)合體的使用方法,需要的朋友可以參考下
    2021-09-09

最新評論