通过进程ID得到进程名

在内核中,通过进程ID,得到进程名称,有多种方法。

我使用了两种方法,第一种是使用ZwOpeProcess得到句柄

然后ObReferenceObjectByHandle函数得到PEPROCESS结构,然后

char *ProcessName = (char*)EProcess + 0x174;

第二种方法是得到PEPROCESS结构之后,使用PsGetProcessImageFileName函数得到进程名。 

具体代码如下:

#include<ntddk.h>
#include<wdm.h>

UCHAR* PsGetProcessImageFileName(PEPROCESS Process);

NTSTATUS Unload(IN PDRIVER_OBJECT  DriverObject)
{
	DbgPrint("驱动已经卸载/n");	
} 

void GetProcessName(ULONG dwPid)
{
	HANDLE ProcessHandle;
	NTSTATUS status;
	OBJECT_ATTRIBUTES  ObjectAttributes;
	CLIENT_ID myCid;
	PEPROCESS EProcess;

	InitializeObjectAttributes(&ObjectAttributes,0,0,0,0); 

	myCid.UniqueProcess = (HANDLE)dwPid;
	myCid.UniqueThread = 0;

	//打开进程,获取句柄
	status = ZwOpenProcess (&ProcessHandle,PROCESS_ALL_ACCESS,&ObjectAttributes,&myCid);
	if (!NT_SUCCESS(status))
	{
		DbgPrint("打开进程出错/n");
		return;
	}
	
	//得到EPROCESS,结构中取进程名
	status = ObReferenceObjectByHandle(ProcessHandle,FILE_READ_DATA,0,KernelMode,&EProcess, 0);
	if (status == STATUS_SUCCESS)
	{
		char *ProcessName = (char*)EProcess + 0x174;
		char *PsName = PsGetProcessImageFileName(EProcess);

		DbgPrint("ProcessName is %s/n",ProcessName);
		DbgPrint("PsName is %s/n",PsName);

                  DbgPrint("PID: %d\n;", PsGetProcessId(EProcess));//PsGetProcessId
	ZwClose(ProcessHandle);
	}
	else
	{
		DbgPrint("Get ProcessName error");
	}
}

NTSTATUS 
  DriverEntry(
    IN PDRIVER_OBJECT  DriverObject,
    IN PUNICODE_STRING  RegistryPath
    )
{
	DbgPrint("驱动已经加载了/n");
	GetProcessName(2044);
	DriverObject->DriverUnload = Unload;	
	return STATUS_SUCCESS;
}


 

DELPHI获取PID代码

procedure TForm1.Button1Click(Sender: TObject);
var
  hw:HWND;
  pid:DWORD;
begin
  hw:=FindWindow(nil,'计算器');
  GetWindowThreadProcessId(hw,pid);
  if pid <> 0 then
  Caption := IntToStr(pid)
end;


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VC获得进程ID获得主线程ID获得窗口句柄获得主窗口获得进程 1.窗口类 窗口句柄 窗口标题 窗口句柄 HWND FindWindow( LPCTSTR lpClassName, //窗口类 可用 VC或者VS自带的Spy++查看 LPCTSTR lpWindowName //窗口标题 ); 举例: 以 记事本为例, 记事本 窗口类 为:NotePad, 窗口标题 视按具体情况而定,假设为"新建 文本文档.txt - 记事本" 窗口类 窗口句柄 TCHAR lpClassName[]=TEXT("NotePad"); HWND hWnd=::FindWindow(lpClassName,NULL); if(hWnd && IsWindow(hWnd)) ::ShowWindow(hWnd,SW_HIDE); 窗口标题 窗口句柄 TCHAR lpWindowName[]=TEXT("新建 文本文档.txt - 记事本"); HWND hWnd=::FindWindow(NULL,lpWindowName); if(hWnd && IsWindow(hWnd)) ::ShowWindow(hWnd,SW_HIDE); 2.窗口句柄 进程ID 窗口句柄 主线程ID 要使用到的函数: DWORD GetWindowThreadProcessId( HWND hWnd, //目标窗口句柄 LPDWORD lpdwProcessId //返回目标窗口对应进程ID ); 例子: DWORD dwProcId=0;//存放返回的进程ID DWORD dwThreadId=0;//存放返回的主线程ID HWND hWnd=XXXX;//这里省略,可能用任务方式得到一个窗口的句柄.比如用1中的方法. dwThreadId=GetWindowThreadProcessId(hWnd,&dwProcId);//同时得到进程ID和主线程ID. 3.窗口HAND CWnd 用CWnd::FromHandle(HWND hWnd)函数.很多类都有这个函数. 4.进程 进程ID (注:进程,即在"任务管理器"中看到的字) 用CCheckObject类(详细实现源文件); 例子: 以记事本为例,进程为 NOTEPAD.EXE (不一定是大写哦,得到任务管理器是显示而定); CCheckObject ch; TCHAR Name[]=TEXT("NOTEPAD.EXE"); DWORD dwProcId=ch.GetProcessId(Name); 5. 进程 主线程ID 例子: CCheckObject ch; TCHAR Name[]=TEXT("NOTEPAD.EXE"); DWORD dwThreadId=ch.GetThreadId(Name); 6. 进程 主窗口句柄 CCheckObject ch; TCHAR Name[]=TEXT("NOTEPAD.EXE"); HWND hWnd=ch.GetTargetWindowHanle(Name); 7. 其它说明 从CCheckObject类和上面的源码中,不难写出从 进程ID 主线程ID 进程ID 主窗口句柄 主线程ID--->主窗口句柄 等等其它类似转换. 对于主窗口,特点如下: A. 不能用进程ID,要用线程ID,因为一个进程可能有多个线程,每个线程都可能会有主窗口. B. 主窗口不会有WS_CHILD属性 C. 主窗口没有父窗口 D. 主窗口一般都有子窗口(这个不是一定的,但是具有普遍性)
要通过进程获取进程ID,可以使用以下步骤: 1. 获取系统中所有正在运行的进程的快照。可以使用函数如`CreateToolhelp32Snapshot`或`EnumProcesses`来实现。 2. 遍历进程快照,逐个比较进程字与目标进程字是否匹配。可以使用函数如`Process32First`和`Process32Next`来遍历进程快照,或者使用`EnumProcesses`函数来获取进程ID列表。 3. 当找到匹配的进程字时,获取进程进程ID。在遍历过程中,可以使用函数如`GetProcessId`来获取进程ID。 以下是一个简单示例代码(使用Windows API)来演示如何通过进程获取进程ID: ```cpp #include <iostream> #include <windows.h> #include <tlhelp32.h> DWORD GetProcessIdByName(const char* processName) { PROCESSENTRY32 pe32; pe32.dwSize = sizeof(PROCESSENTRY32); HANDLE hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); if (hSnapshot == INVALID_HANDLE_VALUE) { return 0; } if (!Process32First(hSnapshot, &pe32)) { CloseHandle(hSnapshot); return 0; } do { if (strcmp(pe32.szExeFile, processName) == 0) { CloseHandle(hSnapshot); return pe32.th32ProcessID; } } while (Process32Next(hSnapshot, &pe32)); CloseHandle(hSnapshot); return 0; } int main() { const char* targetProcessName = "target.exe"; DWORD targetProcessId = GetProcessIdByName(targetProcessName); if (targetProcessId != 0) { std::cout << "Process ID of " << targetProcessName << ": " << targetProcessId << std::endl; } else { std::cout << "Process " << targetProcessName << " not found." << std::endl; } return 0; } ``` 请注意,这只是一个简单的示例,实际应用中可能需要更多的错误处理和逻辑判断。还要注意,获取进程ID可能需要管理员权限或特定的访问权限。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值