首页 > 系统相关 >DLL 动态注入---ImgWalk动态库,这个DLL用来检测被注入的进程中当前载入的各个模块名称---DLL程序

DLL 动态注入---ImgWalk动态库,这个DLL用来检测被注入的进程中当前载入的各个模块名称---DLL程序

时间:2024-09-01 12:50:20浏览次数:17  
标签:__ NULL dwProcessId DLL --- pszLibFile 动态 hProcess

DLL 动态注入—ImgWalk动态库,这个DLL用来检测被注入的进程中当前载入的各个模块名称—exe程序

DLL 动态注入—ImgWalk动态库,这个DLL用来检测被注入的进程中当前载入的各个模块名称—exe程序

文章目录


/*------------------------------------------------------------------------
 22-InjLib.cpp
	ImgWalk动态库,这个DLL用来检测被注入的进程中当前载入的各个模块名称---exe程序
-----------------------------------------------------------------------*/
#include "CmnHdr.h"
#include "Resource.h"
#include <malloc.h>
#include <strsafe.h>
#include <TlHelp32.h>
#include <windowsx.h>
#include <tchar.h>

/
#ifdef UNICODE
	#define InjectLib InjectLibW
	#define EjectLib EjectLibW
#else
	#define InjectLib InjectLibA
	#define EjectLib EjectLibA
#endif

/
BOOL WINAPI InjectLibW(DWORD dwProcessId, PCWSTR pszLibFile);//创建远程线程并注入DLL
BOOL WINAPI InjectLibA(DWORD dwProcessId, PCSTR pszLibFile);
BOOL WINAPI EjectLibW(DWORD dwProcessId, PCWSTR pszLibFile);//将DLL从进程地址空间中撤销
BOOL WINAPI EjectLibA(DWORD dwProcessId, PCSTR pszLibFile);
BOOL  Dlg_OnInitDialog(HWND hwnd, HWND hwndFocus, LPARAM lParam);
void Dlg_OnCommand(HWND hwnd, int id, HWND hwndCtrl, UINT codeNotity);
INT_PTR WINAPI Dlg_Proc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam);
//

int WINAPI _tWinMain(HINSTANCE hInstance,HINSTANCE,PTSTR pszCmdLine,int)
{
	DialogBox(hInstance,MAKEINTRESOURCE(IDD_INJLIB),NULL,Dlg_Proc);
	return 0;
}


INT_PTR WINAPI Dlg_Proc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
	switch (uMsg)
	{
		chHANDLE_DLGMSG(hWnd,WM_INITDIALOG,Dlg_OnInitDialog);
		chHANDLE_DLGMSG(hWnd,WM_COMMAND,Dlg_OnCommand);
	}

	return FALSE;
}

/
BOOL  Dlg_OnInitDialog(HWND hwnd, HWND hwndFocus, LPARAM lParam)
{
	chSETDLGICONS(hwnd,IDI_INJLIB);

	return TRUE;
}

/
void Dlg_OnCommand(HWND hwnd, int id, HWND hwndCtrl, UINT codeNotity)
{
	switch (id)
	{
	case IDCANCEL:
		EndDialog(hwnd, id);
		break;
	case IDC_INJECT:
		DWORD dwProcessId = GetDlgItemInt(hwnd, IDC_PROCESSID, NULL, FALSE);
		if (dwProcessId == 0)
		{
			//如果为0,表示注入本进程
			dwProcessId = GetCurrentProcessId();
		}
		TCHAR szLibFile[MAX_PATH];
		GetModuleFileName(NULL,szLibFile,_countof(szLibFile));//获得当前进程的完整路径
		PTSTR pFileName = _tcsrchr(szLibFile, TEXT('\\')) + 1;
		_tcscpy_s(pFileName,_countof(szLibFile) - (pFileName - szLibFile),TEXT("22-ImgWalk.DLL"));

		if (InjectLib(dwProcessId, szLibFile))
		{
			chVERIFY(EjectLib(dwProcessId,szLibFile));
			chMB("DLL注入/撤消成功!");
		} 
		else
			chMB("DLL注入/撤消失败!");

		break;
	}
}


/
//创建远程线程注入DLL
//参数:dwProcessID --进程ID
//  pszLibFile ---要注入的DLL路径(含名称)
BOOL WINAPI InjectLibW(DWORD dwProcessId, PCWSTR pszLibFile)
{
	BOOL bOk = FALSE;//假设注入失败
	HANDLE hProcess = NULL,hThread = NULL;
	PWSTR pszLibFileRemote = NULL;

	__try {
		//获得目标进程句柄
		hProcess = OpenProcess(
		PROCESS_QUERY_INFORMATION |	//需要检索有关进程的某些信息,例如其令牌、退出代码和优先级类
		PROCESS_CREATE_THREAD |		//For CreateRemoteThread
		PROCESS_VM_OPERATION|		//For VirtualAllocEx/VirtualFreeEx
		PROCESS_VM_WRITE,			//For WriteProcessMemory
			FALSE,dwProcessId);
		if (hProcess == NULL) __leave;

		//计算存储DLL路径所需字节数
		int cch = 1 + lstrlenW(pszLibFile);//字符个数,因strlen不含结尾\0,所以加1
		int cb = cch * sizeof(wchar_t);

		//为远程进程分配内存空间
		pszLibFileRemote = (PWSTR)VirtualAllocEx(hProcess, NULL, cb, MEM_COMMIT, PAGE_READWRITE);
		if (pszLibFileRemote == NULL) __leave;

		//复制DLL路径到远程进程的内存中
		if (!WriteProcessMemory(hProcess, pszLibFileRemote,
			(PVOID)pszLibFile, cb, NULL)) __leave;

		//获取LoadLibraryW在Kernel32.dll中的地址
		//LPTHREAD_START_ROUTINE 函数指针,该函数通知宿主某个线程已开始执行。
		PTHREAD_START_ROUTINE pfnThreadRtn = (PTHREAD_START_ROUTINE)//指向一个函数,该函数通知宿主某个线程已开始执行
			GetProcAddress(GetModuleHandle(TEXT("Kernel32")), "LoadLibraryW");

		if (pfnThreadRtn == NULL) __leave;

		//创建远程线程调用LoadLibraryW
		hThread = CreateRemoteThread(hProcess, NULL, 0, 
			pfnThreadRtn,		//LoadLibraryW(远程进程地址空间中)
			pszLibFileRemote,	//Dll路径名(远程进程地址空间中)
			0, NULL);//立即执行

		if (hThread == NULL) __leave;

		//等待远程线程结束
		WaitForSingleObject(hThread,INFINITE);
		bOk = TRUE;  //注入成功
	}
	__finally {
		//释放用于保存Dll路径名称的内存
		if (pszLibFileRemote != NULL)
			VirtualFreeEx(hProcess, pszLibFileRemote, 0, MEM_RELEASE);
		
		if (hThread != NULL)
			CloseHandle(hThread);
		
		if (hProcess != NULL)
			CloseHandle(hProcess);
		
	}
	return (bOk);

}

BOOL WINAPI InjectLibA(DWORD dwProcessId, PCSTR pszLibFile)
{
	//分配一个栈内存(无需手动释放),用于存储Unicode版本的路径名
	SIZE_T cchSize = lstrlenA(pszLibFile) + 1;//字符个数,含'\0'
	PWSTR pszLibFileW = (PWSTR)_alloca(cchSize * sizeof(wchar_t));

	//将ANSI路径转换为等价的UNICODE
	StringCchPrintfW(pszLibFileW, cchSize, L"%s", pszLibFile);
	return InjectLibW(dwProcessId, pszLibFileW);
}

///
//将DLL从进程地址空间中撤销
//先根据DLL文件名,在进程加载的模块中查找是否该DLL己被加载
//如果被加载,记下这个DLL的句柄。然后创建远程线程去调用FreeLibrary卸载
BOOL WINAPI EjectLibW(DWORD dwProcessId, PCWSTR pszLibFile)
{
	BOOL bOk = FALSE;//假定撤销失败
	HANDLE hthSnapshot = NULL;
	HANDLE hProcess = NULL, hThread = NULL;
	__try
	{
		//抓取进程快照
		hthSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE,//指定进程中加载的所有模块
			dwProcessId);
		if (hthSnapshot == INVALID_HANDLE_VALUE) __leave;

		//获得Unicode版本的目标DLL库句柄
		MODULEENTRY32W me = {sizeof(me)};
		BOOL bFound = FALSE;
		BOOL bMoreMods = Module32FirstW(hthSnapshot, &me);//Unicode版本
		for (;bMoreMods;bMoreMods = Module32NextW(hthSnapshot,&me))
		{
			bFound = (_wcsicmp(me.szModule,pszLibFile) == 0) || 
				(_wcsicmp(me.szExePath,pszLibFile) == 0);
			if(bFound)
				break;
		}
		if (!bFound) __leave;

		//获得目标进程的句柄
		hProcess = OpenProcess(
			PROCESS_QUERY_INFORMATION |
			PROCESS_CREATE_THREAD |
			PROCESS_VM_OPERATION ,
			FALSE, dwProcessId);
		if (hProcess == NULL) __leave;

		//获取FreeLibraray在Kernel32.dll中的地址
		PTHREAD_START_ROUTINE pfnThreadRtn = (PTHREAD_START_ROUTINE)
			GetProcAddress(GetModuleHandle(TEXT("Kernel32")), "FreeLibrary");
		if(pfnThreadRtn == NULL) __leave;

		//创建远程线程
		hThread = CreateRemoteThread(hProcess,
			NULL, 0,
			pfnThreadRtn,
			me.modBaseAddr,
			0, NULL);
		if (hThread == NULL) __leave;

		//等待远程线程结束
		WaitForSingleObject(hThread, INFINITE);
		bOk = TRUE;  //撤销成功
	}
	__finally
	{
		if (hthSnapshot != NULL)
			CloseHandle(hthSnapshot);
		if (hThread != NULL)
			CloseHandle(hThread);
		if (hProcess != NULL)
			CloseHandle(hProcess);
	}

	return bOk;
}

BOOL WINAPI EjectLibA(DWORD dwProcessId, PCSTR pszLibFile)
{
	//分配一个栈内存(无需手动释放),用于存储Unicode版本的路径名
	SIZE_T cchSize = lstrlenA(pszLibFile) + 1;//字符个数,含'\0'
	PWSTR pszLibFileW = (PWSTR)_alloca(cchSize * sizeof(wchar_t));

	//将ANSI路径转换为等价的UNICODE
	StringCchPrintfW(pszLibFileW, cchSize, L"%s", pszLibFile);
	return EjectLibW(dwProcessId, pszLibFileW);
}

标签:__,NULL,dwProcessId,DLL,---,pszLibFile,动态,hProcess
From: https://blog.csdn.net/zhyjhacker/article/details/141782928

相关文章

  • spring学习日记-day5-代理模式
    一、学习目标        代理模式是一种常用的设计模式,它主要用于在不修改原有对象代码的情况下,通过引入一个代理对象来控制对原有对象的访问,从而增强原有对象的功能。代理模式主要分为两种:静态代理和动态代理。尽管Spring框架本身更多地利用了动态代理来实现其功能,但理......
  • CohereForAI更新企业级开源模型 c4ai-command-r-08-2024和c4ai-command-r-plus-08-202
    C4AICommandR08-2024是一个350亿参数高性能生成模型的研究版本。CommandR08-2024是一个大型语言模型,采用开放式权重,针对推理、总结和问题解答等各种用例进行了优化。CommandR08-2024具备多语言生成功能,曾在23种语言上进行过训练,并在10种语言上进行过评估......
  • 阿里巴巴发布 Qwen2-VL 人工智能模型,具备先进的视频分析和推理能力
    中国阿里巴巴集团的云计算部门阿里云周四宣布推出一款名为Qwen2-VL的新型人工智能模型,该模型具有高级视觉理解能力和多语言对话能力。该公司在Qwen-VL人工智能模型的基础上,历时一年研发出了新模型,并表示它可以实现对长度超过20分钟的高质量视频的理解。据阿里巴巴......
  • [USACO2.4] 两只塔姆沃斯牛 The Tamworth Two--记忆化题解
    题目复述:链接跳转:[USACO2.4]两只塔姆沃斯牛TheTamworthTwo-洛谷#[USACO2.4]两只塔姆沃斯牛TheTamworthTwo##题目描述两只牛逃跑到了森林里。FarmerJohn开始用他的专家技术追捕这两头牛。你的任务是模拟他们的行为(牛和John)。追击在$10\times10$的平面网......
  • [蓝桥杯 2020 省 A1] 超级胶水--题解
    题目再现:链接跳转:[蓝桥杯2020省A1]超级胶水-洛谷#[蓝桥杯2020省A1]超级胶水##题目描述小明有$n$颗石子,按顺序摆成一排,他准备用胶水将这些石子粘在一起。 每颗石子有自己的重量,如果将两颗石子粘在一起,将合并成一颗新的石子,重量是这两颗石子的重量之和。为......
  • [蓝桥杯 2016 省 A] 密码脱落--最长公共子序列题解
    题目复述:题目链接:[蓝桥杯2016省A]密码脱落-洛谷#[蓝桥杯2016省A]密码脱落##题目描述X星球的考古学家发现了一批古代留下来的密码。这些密码是由A、B、C、D四种植物的种子串成的序列。仔细分析发现,这些密码串当初应该是前后对称的(也就是我们说的回文串)。......
  • ctfhub-web-SSRF通关攻略
    一、内网访问1.打开ctfhub给的环境地址2.观察题目发现让我们访问127.0.0.1下的flag.php在地址栏后面有一个url参数 ?url=http://127.0.0.1/flag.php 提交即可二、伪协议读取文件1.打开ctfhub给的环境2.观察题目发现让我们读取flag.php文件读取文件用到的协议是......
  • 第九章 动态规划Part13
    目录任务647.回文子串思路516.最长回文子序列思路任务647.回文子串给你一个字符串s,请你统计并返回这个字符串中回文子串的数目。回文字符串是正着读和倒过来读一样的字符串。子字符串是字符串中的由连续字符组成的一个序列。思路这道题的DP思路不是很直观,dp表示的......
  • 新赛道-2024.8 CSP-J组月赛-T4
    题目描述王老师最近搬家了,需要购置 a 台家电、b 件家具和 c 个装饰。他来到了商场,商场正好在举行优惠大酬宾,每家店铺都推出了一系列活动。一共有 n=a+b+c 家店铺,活动期间在第 i 家店铺购买家电只需要 ai​ 元一台,购买家具只需要 bi​ 元一件,购买装饰只需要 ci​......