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

利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能

 更新時(shí)間:2019年10月15日 09:56:44   作者:OneTrainee  
在R3層的模塊隱藏,我們需要做的就是將其該鏈表斷鏈,將某一模塊從這個(gè)雙向鏈表中摘除,這樣再調(diào)用傳統(tǒng)的API時(shí)就會(huì)搜索不到。本文重點(diǎn)給大家介紹利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能,感興趣的朋友一起看看吧

一、模塊隱藏的實(shí)現(xiàn)原理

  普通API查找模塊實(shí)現(xiàn)思路:其通過查詢在R3中的PEB(Process Environment Block 進(jìn)程環(huán)境塊)與TEB(Thread Environment Block 進(jìn)程環(huán)境塊)來找到一個(gè)雙向鏈表,通過遍歷雙向鏈表中某一成員(字符串)來查找全部模塊。

  模塊隱藏實(shí)現(xiàn)思路:在R3層的模塊隱藏,我們需要做的就是將其該鏈表斷鏈,將某一模塊從這個(gè)雙向鏈表中摘除,這樣再調(diào)用傳統(tǒng)的API時(shí)就會(huì)搜索不到。

二、結(jié)構(gòu)體成員詳細(xì)介紹

<1> TEB結(jié)構(gòu)體 -- 內(nèi)存地址為 fs:[0] 處。

使用Windbg的 "dt _TEB"命令來查看TEB結(jié)構(gòu)體

kd> dt _TEB 
ntdll!_TEB
 +0x000 NtTib : _NT_TIB
 +0x01c EnvironmentPointer : Ptr32 Void
 +0x020 ClientId : _CLIENT_ID
 +0x028 ActiveRpcHandle : Ptr32 Void
 +0x02c ThreadLocalStoragePointer : Ptr32 Void
 +0x030 ProcessEnvironmentBlock : Ptr32 _PEB
 +0x034 LastErrorValue : Uint4B

1. 屬性介紹 

  1.1)_NT_TIB:重點(diǎn)兩個(gè)屬性,棧頂與棧大小。

   http://www.nirsoft.net/kernel_struct/vista/NT_TIB.html

  1.2) _CLIENT_ID: 存儲(chǔ)該進(jìn)程ID與當(dāng)前主線程ID。

  https://docs.microsoft.com/en-us/openspecs/windows_protocols/ms-tsts/a11e7129-685b-4535-8d37-21d4596ac057?redirectedfrom=MSDN

  1.3) _PEB:進(jìn)程環(huán)境塊 ,記住其在 TEB 偏移 0x30處即可。

2. 通過olldbg查看該結(jié)構(gòu)體

  2.1) 打開任意進(jìn)程,在寄存器窗口找到 fs:[0],查看其內(nèi)存地址。

    

  2.2) 在內(nèi)存窗口使用命令 "db 5E7000" 跳轉(zhuǎn)到該內(nèi)存,使用地址格式(長型-地址)顯示。

    

<2> PEB結(jié)構(gòu)體 -- fs:[0x30]

使用 Windbg 指令 dt _PEB 查看 PEB結(jié)構(gòu)體,重點(diǎn)關(guān)注最后一個(gè) 進(jìn)程加載信息表。

kd> dt _PEB
ntdll!_PEB
 +0x000 InheritedAddressSpace : UChar
 +0x001 ReadImageFileExecOptions : UChar
 +0x002 BeingDebugged : UChar
 +0x003 BitField : UChar
 +0x003 ImageUsesLargePages : Pos 0, 1 Bit
 +0x003 IsProtectedProcess : Pos 1, 1 Bit
 +0x003 IsLegacyProcess : Pos 2, 1 Bit
 +0x003 IsImageDynamicallyRelocated : Pos 3, 1 Bit
 +0x003 SkipPatchingUser32Forwarders : Pos 4, 1 Bit
 +0x003 SpareBits : Pos 5, 3 Bits
 +0x004 Mutant : Ptr32 Void
 +0x008 ImageBaseAddress : Ptr32 Void
 +0x00c Ldr : Ptr32 _PEB_LDR_DATA // PEB_LOADER_DATA 進(jìn)程加載信息表

1. 查看 _PEB_LDR_DATA 進(jìn)程加載信息表 的結(jié)構(gòu)體

  1.1)重點(diǎn)關(guān)注 0x00c處的指針,其指向 _PEB_LDR_DATA 這個(gè)結(jié)構(gòu)體,在這個(gè)結(jié)構(gòu)體中 0x00c、0x014、0x01c 分別表示 模塊加載順序 / 加載后在內(nèi)存中的順序 / 模塊初始化的順序。

kd > dt _PEB_LDR_DATA
 ntdll!_PEB_LDR_DATA
 + 0x000 Length : Uint4B
 + 0x004 Initialized : UChar
 + 0x008 SsHandle : Ptr32 Void
 + 0x00c InLoadOrderModuleList : _LIST_ENTRY // 模塊加載順序
 + 0x014 InMemoryOrderModuleList : _LIST_ENTRY // 加載后在內(nèi)存中的順序
 + 0x01c InInitializationOrderModuleList : _LIST_ENTRY // 模塊初始化的順序
 + 0x024 EntryInProgress : Ptr32 Void
 + 0x028 ShutdownInProgress : UChar
 + 0x02c ShutdownThreadId : Ptr32 Void

  2.2)理解其三個(gè)成員的順序,其指向_LDR_DATA_TABLE_ENTRY元素中開始的三個(gè)成員,而 _LDR_DATA_TABLE_ENTRY 中存儲(chǔ)著就是關(guān)于有關(guān)模塊信息的元素(比如模塊名等)

 kd > dt _LDR_DATA_TABLE_ENTRY
 ntdll!_LDR_DATA_TABLE_ENTRY
 + 0x000 InLoadOrderLinks : _LIST_ENTRY   
 + 0x008 InMemoryOrderLinks : _LIST_ENTRY
 + 0x010 InInitializationOrderLinks : _LIST_ENTRY
 + 0x018 DllBase : Ptr32 Void  // 模塊基地址
 + 0x01c EntryPoint : Ptr32 Void  // 入口函數(shù)(對(duì)于 exe 模塊有效)
 + 0x020 SizeOfImage : Uint4B  // 模塊大小
 + 0x024 FullDllName : _UNICODE_STRING  // 完成模塊名稱(帶路徑)
 + 0x02c BaseDllName : _UNICODE_STRING // 模塊名稱
 + 0x034 Flags : Uint4B

2. 使用olldbg來查看查找首先加載模塊的模塊名稱(TEB->PEB-> InLoadOrderModuleList -> BaseDllName)

  2.1)接之前TEB內(nèi)容查找到PEB的所在位置 fs:[0x30]。

  2.2) 在其0x00c處發(fā)現(xiàn)InLoadOrderModuleList成員,其指向的是一個(gè)_LDR_DATA_TABLE_ENTRY 結(jié)構(gòu)體。

    

  2.3) 跳轉(zhuǎn)到 _LDR_DATA_TABLE_ENTRY 結(jié)構(gòu)體,從0x0c開始依次是三個(gè) _LIST_ENTRY 結(jié)構(gòu)體,該結(jié)構(gòu)體雙向鏈表存儲(chǔ)著兩個(gè)地址。

    

  2.4)選中第一個(gè)進(jìn)入,在其偏移0x02c處(UNICODE結(jié)構(gòu)體占四字),可以查看字符串名稱。

    

  2.5)通過開頭 _LIST_ENTRY結(jié)構(gòu)體可以遍歷前一個(gè)模塊的內(nèi)容和下一個(gè)模塊的內(nèi)容。

    

三、利用C++斷鏈來實(shí)現(xiàn)模塊隱藏

  如果你看懂上面分析,則源代碼非常好理解。

// 隱藏模塊.cpp : 此文件包含 "main" 函數(shù)。程序執(zhí)行將在此處開始并結(jié)束。
//
#include "pch.h"
#include <iostream>
#include <Windows.h>
/* 所需要的結(jié)構(gòu)體
1. _LDR_DATA_TABLE_ENTRY 鏈表指向數(shù)據(jù)
2. _PEB_LDR_DATA 表示其 PEB0x處指向的數(shù)據(jù)表
3. _LIST_ENTRY 指針指向的鏈表
*/
typedef struct _LSA_UNICODE_STRING {
 USHORT Length;
 USHORT MaximumLength;
 PWSTR Buffer;
}
UNICODE_STRING, *PUNICODE_STRING;
typedef struct _PEB_LDR_DATA
{
 DWORD Length; // +0x00
 bool Initialized; // +0x04
 PVOID SsHandle; // +0x08
 LIST_ENTRY InLoadOrderModuleList; // +0x0c
 LIST_ENTRY InMemoryOrderModuleList; // +0x14
 LIST_ENTRY InInitializationOrderModuleList;// +0x1c
} PEB_LDR_DATA, *PPEB_LDR_DATA; // +0x24
typedef struct _LDR_MODULE
{
 LIST_ENTRY InLoadOrderModuleList;
 LIST_ENTRY InMemoryOrderModuleList;
 LIST_ENTRY InInitializationOrderModuleList;
 void* BaseAddress;
 void* EntryPoint;
 ULONG SizeOfImage;
 UNICODE_STRING FullDllName;
 UNICODE_STRING BaseDllName;
 ULONG Flags;
 SHORT LoadCount;
 SHORT TlsIndex;
 HANDLE SectionHandle;
 ULONG CheckSum;
 ULONG TimeDateStamp;
} LDR_MODULE, *PLDR_MODULE;
//所謂模塊句柄,即該模塊的入口地址
void hide_module(char* szDllName)
{
 HMODULE hMod = GetModuleHandleA(szDllName);
 PLIST_ENTRY Head, Cur;
 PPEB_LDR_DATA ldr;
 PLDR_MODULE ldm;
 __asm
 {
 mov eax, fs:[0x30]
 mov ecx, [eax + 0x0c] //Ldr 
 mov ldr, ecx
 }
 Head = &(ldr->InLoadOrderModuleList);
 Cur = Head->Flink;
 do
 {
 ldm = CONTAINING_RECORD(Cur, LDR_MODULE, InLoadOrderModuleList);
 if (hMod == ldm->BaseAddress)
 {
 // 三個(gè)鏈表同時(shí)給斷掉
 ldm->InLoadOrderModuleList.Blink->Flink =
 ldm->InLoadOrderModuleList.Flink;
 ldm->InLoadOrderModuleList.Flink->Blink =
 ldm->InLoadOrderModuleList.Blink;
 //
 ldm->InInitializationOrderModuleList.Blink->Flink =
 ldm->InInitializationOrderModuleList.Flink;
 ldm->InInitializationOrderModuleList.Flink->Blink =
 ldm->InInitializationOrderModuleList.Blink;
 //
 ldm->InMemoryOrderModuleList.Blink->Flink =
 ldm->InMemoryOrderModuleList.Flink;
 ldm->InMemoryOrderModuleList.Flink->Blink =
 ldm->InMemoryOrderModuleList.Blink;
 break;
 }
 Cur = Cur->Flink;
 } while (Head != Cur);
}
int main()
{
 // 通過模塊名,來獲取模塊句柄
 printf("****按任意鍵隱藏模塊*****");
 getchar();
 hide_module((char*)"kernel32.dll");
 printf("****隱藏模塊完成*****");
 getchar();
 getchar();
}

總結(jié)

以上所述是小編給大家介紹的利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能,希望對(duì)大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • C語言實(shí)現(xiàn)去除字符串中空格的簡單實(shí)例

    C語言實(shí)現(xiàn)去除字符串中空格的簡單實(shí)例

    下面小編就為大家?guī)硪黄狢語言實(shí)現(xiàn)去除字符串中空格的簡單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-05-05
  • C/C++ Qt 基本文件讀寫的基本使用(2種實(shí)現(xiàn))

    C/C++ Qt 基本文件讀寫的基本使用(2種實(shí)現(xiàn))

    文件的讀寫是很多應(yīng)用程序具有的功能,本文主要介紹了兩種實(shí)現(xiàn)方法,第一種使用QFile類的IODevice讀寫功能直接讀寫,第二種是利用 QFile和QTextStream結(jié)合起來,用流的方式進(jìn)行文件讀寫
    2021-11-11
  • C++?Qt開發(fā)之運(yùn)用QJSON模塊解析數(shù)據(jù)

    C++?Qt開發(fā)之運(yùn)用QJSON模塊解析數(shù)據(jù)

    JSON(JavaScript?Object?Notation)是一種輕量級(jí)的數(shù)據(jù)交換格式,它易于人閱讀和編寫,也易于機(jī)器解析和生成,本文主要介紹了Qt如何運(yùn)用QJson組件的實(shí)現(xiàn)對(duì)JSON文本的靈活解析功能,需要的可以參考下
    2024-01-01
  • C語言 基本語法示例講解

    C語言 基本語法示例講解

    本篇文章主要講解C語言 基本語法,這里提供簡單的示例和代碼來詳細(xì)講解C語言的基本語法,開始學(xué)習(xí)C語言的朋友可以看一下
    2016-08-08
  • C語言關(guān)鍵字總結(jié)解析

    C語言關(guān)鍵字總結(jié)解析

    這篇文章主要介紹了C語言關(guān)鍵字總結(jié)解析,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是本文的詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C語言實(shí)現(xiàn)堆的簡單操作的示例代碼

    C語言實(shí)現(xiàn)堆的簡單操作的示例代碼

    堆(heap)是計(jì)算機(jī)科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱。堆通常是一個(gè)可以被看做一棵樹的數(shù)組對(duì)象。本文介紹了C語言中堆的一些簡單操作,需要的可以參考一下
    2022-11-11
  • Qt串口通信開發(fā)之QSerialPort模塊簡單使用方法與實(shí)例

    Qt串口通信開發(fā)之QSerialPort模塊簡單使用方法與實(shí)例

    這篇文章主要介紹了Qt串口通信開發(fā)之QSerialPort模塊簡單使用方法與實(shí)例,需要的朋友可以參考下
    2020-03-03
  • c++快速排序詳解

    c++快速排序詳解

    快速排序總體思想:先找到一個(gè)樞軸,讓他作為分水嶺。通過一趟排序?qū)⒋判虻挠涗浄指畛瑟?dú)立的兩部分,前面一部分都比樞軸小,后面一部分逗比樞軸大,然后又分別對(duì)這兩部分記錄繼續(xù)進(jìn)行遞歸的排序,達(dá)到整個(gè)序列有序的目的。
    2017-05-05
  • linux c 獲得當(dāng)前進(jìn)程的進(jìn)程名和執(zhí)行路徑(示例)

    linux c 獲得當(dāng)前進(jìn)程的進(jìn)程名和執(zhí)行路徑(示例)

    如何得到當(dāng)前進(jìn)程的進(jìn)程名和執(zhí)行路徑。寫了個(gè)程序分享一下
    2013-07-07
  • 詳解C語言結(jié)構(gòu)體中的char數(shù)組如何賦值

    詳解C語言結(jié)構(gòu)體中的char數(shù)組如何賦值

    這篇文章主要給大家介紹了關(guān)于C語言結(jié)構(gòu)體中的char數(shù)組如何賦值的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-03-03

最新評(píng)論