首页
社区
课程
招聘
[求助]如何在wow64进程中获得本进程EPROCESS结构地址
发表于: 2016-2-1 14:08 4973

[求助]如何在wow64进程中获得本进程EPROCESS结构地址

2016-2-1 14:08
4973
我们知道在win32中可以用ZwQuerySystemInformation获得SystemHandleInformation(16)的信息,然后遍历_SYSTEM_HANDLE_INFORMATION结构,对比pid,找到自己进程的pid然后对比handle,找到自己进程openprocess的handle那个的object就是本进程EPROCESS的地址,下面这个链接有代码
http://www.xfocus.net/articles/200406/706.html
---------------------------------------------------
这些东西在win32上都能运行,没有问题,但是在wow64下面运行就不行了。
尽管本进程已经OpenProcess打开了自己,但是在遍历数据的时候却没有找到自己的OpenProcess句柄,进而找不到本进程的EPROCESS地址。。。。

代码如下
#include <stdio.h>
#include <windows.h>
#define alloc(a) VirtualAlloc(0,a,MEM_COMMIT|MEM_RESERVE,PAGE_READWRITE)
#define freea(a) VirtualFree(a,0,MEM_RELEASE)
typedef struct {
	PVOID   Unknown1;
	PVOID   Unknown2;
	PVOID   Base;
	ULONG   Size;
	ULONG   Flags;
	USHORT  Index;
	USHORT  NameLength;
	USHORT  LoadCount;
	USHORT  PathLength;
	CHAR    ImageName[256];
} SYSTEM_MODULE_INFORMATION_ENTRY, *PSYSTEM_MODULE_INFORMATION_ENTRY;
typedef struct {
	ULONG   Count;
	SYSTEM_MODULE_INFORMATION_ENTRY Module[1];
} SYSTEM_MODULE_INFORMATION, *PSYSTEM_MODULE_INFORMATION;
typedef struct _SYSTEM_HANDLE
{
	DWORD ProcessId;
	//	USHORT	CreatorBackTraceIndex;
	UCHAR ObjectTypeNumber;
	UCHAR Flags;
	USHORT Handle;
	PVOID Object;
	ACCESS_MASK GrantedAccess;
} SYSTEM_HANDLE, *PSYSTEM_HANDLE;
typedef struct _SYSTEM_HANDLE_INFORMATION
{
	ULONG HandleCount; /* Or NumberOfHandles if you prefer. */
	SYSTEM_HANDLE Handles[1];
} SYSTEM_HANDLE_INFORMATION, *PSYSTEM_HANDLE_INFORMATION;
typedef enum _SYSTEM_INFORMATION_CLASS {
	SystemModuleInformation = 11,
	SystemHandleInformation = 16
} SYSTEM_INFORMATION_CLASS;

typedef NTSTATUS(WINAPI *_NtQuerySystemInformation)(
	SYSTEM_INFORMATION_CLASS SystemInformationClass,
	PVOID SystemInformation,
	ULONG SystemInformationLength,
	PULONG ReturnLength
	);

void main()
{
	_NtQuerySystemInformation NtQuerySystemInformation=(_NtQuerySystemInformation)GetProcAddress(LoadLibrary(L"ntdll.dll"),"NtQuerySystemInformation");
	PSYSTEM_MODULE_INFORMATION pmodinf;
	PSYSTEM_HANDLE_INFORMATION phaninf;
	ULONG len = 0;
	char kname[260] = { 0 };
	PVOID kbase = NULL;
	DWORD cpid = GetCurrentProcessId();
	HANDLE self = OpenProcess(PROCESS_QUERY_INFORMATION, NULL, cpid);
	HANDLE self2 = NULL;

	DuplicateHandle(GetCurrentProcess(), GetCurrentProcess(), GetCurrentProcess(), &self2, NULL, NULL, NULL);
	NtQuerySystemInformation(SystemModuleInformation, NULL, 0, &len);
	pmodinf = (PSYSTEM_MODULE_INFORMATION)alloc(len);
	RtlSecureZeroMemory(pmodinf, len);
	NtQuerySystemInformation(SystemModuleInformation, pmodinf, len, &len);

	lstrcpyA(kname, pmodinf->Module[0].ImageName);
	kbase = pmodinf->Module[0].Base;
	printf("kbase:%x\tkname:%s\n", kbase, kname);
	HANDLE hntos = LoadLibraryA(kname);

	len = 4096 * 16 * 16;
//	NtQuerySystemInformation(SystemHandleInformation, NULL, 0, &len);
	phaninf = (PSYSTEM_HANDLE_INFORMATION)alloc(len);
	RtlSecureZeroMemory(phaninf, len);
	NtQuerySystemInformation(SystemHandleInformation, phaninf, len, &len);

	for (UINT i = 0; i < phaninf->HandleCount; i++)
	{
		if (phaninf->Handles[i].ProcessId==cpid)
		{
			printf("ObjectType:%d\n", phaninf->Handles[i].ObjectTypeNumber);
			printf("Handle:%x,OpenProcessHandle:%x,DuplicateHandle:%x\n", phaninf->Handles[i].Handle, self,self2);
			puts("");
			if (phaninf->Handles[i].Handle==(USHORT)self)
			{
				puts("=============================");
				printf("OpenProcessHandle\tEProcess Found!0x%x\n", phaninf->Handles[i].Object);
				puts("=============================");
			}
			if (phaninf->Handles[i].Handle == (USHORT)self2)
			{
				puts("=============================");
				printf("DuplicateHandle\tEProcess Found!0x%x\n", phaninf->Handles[i].Object);
				puts("=============================");
			}
		}
	}

	freea(phaninf);
	freea(pmodinf);

}


这个在wow64上就不能获得正确的地址。。
那么问题来了,有没有类似的方法在wow64上获得自己进程的EPROCSS地址呢?
小菜第一次发帖,求各位表哥解答

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

收藏
免费 0
支持
分享
最新回复 (4)
雪    币: 80
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
补充一下。。不能进Ring0,求在Ring3下的解决方案。。小菜感激不尽。。
2016-2-1 14:09
0
雪    币: 522
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
3
ring3 下  拿EPROCESS也沒什麽意義啊
2016-2-5 10:06
0
雪    币: 80
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
只是想问下行不行。。。某个项目要用到
2016-2-14 23:38
0
雪    币: 522
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
5
64位下比32位多了很多限制    你可以试试先给进程个SYSTEM权限
再单步看看这段代码的运行情况  是在哪个函数那出的问题
2016-2-19 09:55
0
游客
登录 | 注册 方可回帖
返回
//