windows 内核中获取当前进程路径

 

BOOLEAN getCurProcPath( PEPROCESS curproc, PUNICODE_STRING uni_ImagePathName )
{
    /*
	wdbg cmd : dt _EPROCESS 0xFFFFFA801AB1D940
	0xFFFFFA801AB1D940 == curproc
	+0x3e8 Peb              : 0x000007f6`f713e000 _PEB
	wdbg cmd : dt _PEB 0x000007f6`f713e000
	+0x020 ProcessParameters : 0x00000000`001f1210 _RTL_USER_PROCESS_PARAMETERS
	wdbg cmd : dt _RTL_USER_PROCESS_PARAMETERS  0x00000000`001f1210
	+0x060 ImagePathName    : _UNICODE_STRING "C:\Windows\Explorer.EXE"
	+0x070 CommandLine      : _UNICODE_STRING "C:\Windows\Explorer.EXE"
	*/
	PPEB		curPeb = NULL;
	ULONG_PTR  ProcessParameters = NULL;

	KAPC_STATE ApcState;

	curPeb = PsGetProcessPeb( curproc );

	KeStackAttachProcess( curproc, &ApcState );   // 切入进程地址空间 
	ProcessParameters = *( ULONG_PTR* )( ( ULONG_PTR )curPeb + 0x20 );
	
	RtlAppendUnicodeToString( uni_ImagePathName, L"\\??\\" );

	RtlAppendUnicodeStringToString( uni_ImagePathName, ( PUNICODE_STRING )( ( ULONG_PTR )ProcessParameters + 0x60 ) );
	KeUnstackDetachProcess( &ApcState );      // 切出进程 
	return TRUE;
}

使用方法如下

    PEPROCESS	curproc =PsGetCurrentProcess();
    UNICODE_STRING uni_ImagePathName = { 0};
    uni_ImagePathName.Length = 0;
	uni_ImagePathName.MaximumLength = MAX_PATH;
	uni_ImagePathName.Buffer = ( PWCH )ExAllocatePoolWithTag( NonPagedPool, MAX_PATH, NULL );
	getCurProcPath( curproc, &uni_ImagePathName );    

同样的方法,还可以获取到很多值,根据注释里面的方法,慢慢研究吧,朋友!

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值