龙马谷

 找回密码
 立即注册

QQ登录

只需一步,快速开始

龙马谷VIP会员办理客服QQ:82926983(如果临时会话没有收到回复,请先加QQ好友再发。)
1 [已完结] GG修改器新手入门与实战教程 31课 2 [已完结] GG修改器美化修改教程 6课 3 [已完结] GG修改器Lua脚本新手入门教程 12课
4 [已完结] 触动精灵脚本新手入门必学教程 22课 5 [已完结] 手游自动化脚本入门实战教程 9课 6 [已完结] C++射击游戏方框骨骼透视与自瞄教程 27课
7 [已完结] C++零基础UE4逆向开发FPS透视自瞄教程 29课 8 [已完结] C++零基础大漠模拟器手游自动化辅助教程 22课 9 [已完结] C++零基础开发DXF内存脚本辅助教程 32课
以下是天马阁VIP教程,本站与天马阁合作,赞助VIP可以获得天马阁对应VIP会员,名额有限! 点击进入天马阁论坛
1 [已完结] x64CE与x64dbg入门基础教程 7课 2 [已完结] x64汇编语言基础教程 16课 3 [已完结] x64辅助入门基础教程 9课
4 [已完结] C++x64内存辅助实战技术教程 149课 5 [已完结] C++x64内存检测与过检测技术教程 10课 6 [已完结] C+x64二叉树分析遍历与LUA自动登陆教程 19课
7 [已完结] C++BT功能原理与x64实战教程 29课 8 [已完结] C+FPS框透视与自瞄x64实现原理及防护思路
查看: 9514|回复: 0

在内核驱动中,获得到当前进程的全路径。

[复制链接]

5

主题

0

回帖

7

积分

编程入门

Rank: 1

龙马币
20

作者:guijc
在应用层想要获得一个进程的全路径,有一个很简单的API函数,但是在内核中却没有提供这样的函数,上次看了一位前辈的帖子,根据他的思路写出了下面的代码,欢迎大家的评论

代码思路如下:
1. 利用ZwQueryInformationProcess得到当前进程的NT路径
2. 用ZwOpenFile打开NT路径,获得进程的句柄
3. 用ObReferenceObjectByHandle获得内核对象(FileObj)
4. 获得盘符(C:\),RtlVolumeDeviceToDosName(FileObj->DeviceObject, &DosName);
5. 拼接路径,RtlAppendUnicodeStringToString(&ImageName, &FileObj->FileName);

好了废话不多,直接上代码:
  1. void GetProcessImageName(PANSI_STRING ImageFileName)
  2. {  
  3.     UNICODE_STRING  ImageName = {0};
  4.     PUNICODE_STRING Buffer = NULL;
  5.     ULONG ReturnLength = 0;
  6.     NTSTATUS status = 0;  

  7.     HANDLE FileHandle = NULL;
  8.     OBJECT_ATTRIBUTES ObjectAttributes = {0};
  9.     IO_STATUS_BLOCK IoStatusBlock = {0};
  10.     PFILE_OBJECT FileObj = NULL;
  11.     UNICODE_STRING DosName = {0};

  12.     status = ZwQueryInformationProcess(
  13.                             NtCurrentProcess(),
  14.                             ProcessImageFileName,
  15.                             NULL,
  16.                             0,
  17.                             &ReturnLength);

  18.     if(STATUS_INFO_LENGTH_MISMATCH != status ||  0 == ReturnLength){
  19.         return;
  20.     }

  21.     Buffer = ExAllocatePool(NonPagedPool, ReturnLength);
  22.     if(NULL == Buffer){
  23.         goto Clean;
  24.     }
  25.    
  26.     status = ZwQueryInformationProcess(
  27.                             NtCurrentProcess(),
  28.                             ProcessImageFileName,
  29.                             Buffer,
  30.                             ReturnLength,
  31.                             &ReturnLength);

  32.     if(!NT_SUCCESS(status)){
  33.         goto Clean;
  34.     }

  35.     InitializeObjectAttributes( &ObjectAttributes,
  36.                             Buffer,
  37.                             OBJ_KERNEL_HANDLE,
  38.                             NULL,
  39.                             NULL );

  40.     status = ZwOpenFile(&FileHandle, 0, &ObjectAttributes, &IoStatusBlock, 0, 0);
  41.     if (!NT_SUCCESS (status)){
  42.        goto Clean;
  43.     }

  44.     status = ObReferenceObjectByHandle(FileHandle, 0, NULL, KernelMode, &FileObj, NULL);
  45.     if (!NT_SUCCESS (status)){
  46.        goto Clean;
  47.     }

  48.     if(FileObj->DeviceObject && FileObj->FileName.Buffer){
  49.    
  50.         RtlVolumeDeviceToDosName(FileObj->DeviceObject, &DosName);

  51.         ImageName.MaximumLength = DosName.Length + FileObj->FileName.Length;
  52.         ImageName.Buffer = ExAllocatePool(NonPagedPool, ImageName.MaximumLength);        

  53.         RtlCopyUnicodeString(&ImageName, &DosName);
  54.         RtlAppendUnicodeStringToString(&ImageName, &FileObj->FileName);
  55.         
  56.         RtlUnicodeStringToAnsiString(ImageFileName ,&ImageName, TRUE);
  57.         RtlFreeUnicodeString(&ImageName);
  58.         RtlFreeUnicodeString(&DosName);
  59.     }
  60.    
  61. Clean:

  62.     if(Buffer){
  63.         ExFreePool (Buffer);
  64.     }

  65.     if(FileHandle){
  66.         ZwClose(FileHandle);
  67.     }   

  68.     if(FileObj){
  69.         ObDereferenceObject(FileObj);
  70.     }

  71. }
复制代码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

龙马谷| C/C++辅助教程| 安卓逆向安全| 论坛导航| 免责申明|Archiver|
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表龙马谷立场!
任何人不得以任何方式翻录、盗版或出售本站视频,一经发现我们将追究其相关责任!
我们一直在努力成为最好的编程论坛!
Copyright© 2018-2021 All Right Reserved.
在线客服
快速回复 返回顶部 返回列表