java - 使用 JNA 获取正在运行的进程

标签 java winapi process jna

我正在尝试获取 Windows 计算机上当前正在运行的所有进程的列表。

我正在尝试通过 JNA 进行 winapi 调用 EnumProcesses -> OpenProcess -> GetModuleBaseNameW -> CloseHandle 它在 OpenProcess 调用时失败。 GetLastError 返回 5 (ERROR_ACCESS_DENIED)。

这是我的代码:

public static final int PROCESS_QUERY_INFORMATION = 0x0400;
public static final int PROCESS_VM_READ = 0x0010;
public static final int PROCESS_VM_WRITE = 0x0020;
public static final int PROCESS_VM_OPERATION = 0x0008;


public interface Psapi extends StdCallLibrary {
    Psapi INSTANCE = (Psapi) Native.loadLibrary("Psapi", Psapi.class);

    boolean EnumProcesses(int[] ProcessIDsOut, int size, int[] BytesReturned);

    DWORD GetModuleBaseNameW(Pointer hProcess, Pointer hModule, byte[] lpBaseName, int nSize);

}

public interface Kernel32 extends StdCallLibrary {
    Kernel32 INSTANCE = (Kernel32) Native.loadLibrary("Kernel32", Kernel32.class);

    Pointer OpenProcess(int dwDesiredAccess, boolean bInheritHandle, int dwProcessId);

    boolean CloseHandle(Pointer hObject);

}

public static void main(String[] args) {
    int[] processlist = new int[1024];
    int[] dummylist = new int[1024];
    Psapi.INSTANCE.EnumProcesses(processlist, 1024, dummylist);

    for (int pid : processlist) {
        System.out.println(pid);
        Pointer ph = Kernel32.INSTANCE.OpenProcess(PROCESS_VM_READ, false, pid);

        try {
            Thread.sleep(1000);
        } catch (Exception ignore) {
        }

        System.err.println(com.sun.jna.platform.win32.Kernel32.INSTANCE.GetLastError()); // <- 5
        System.err.println(ph); // <- null
        if (ph != null) {
            byte[] filename = new byte[512];
            Psapi.INSTANCE.GetModuleBaseNameW(ph, new Pointer(0), filename, 512);

            try {
                Thread.sleep(1000);
            } catch (Exception ignore) {
            }

            System.err.println(Native.toString(filename));
            Kernel32.INSTANCE.CloseHandle(ph);
        }

    }

}

最佳答案

使用PROCESS_VM_READ调用OpenProcess意味着您想要读取该进程的内存。为此,您需要 SE_DEBUG_PRIVLEGE。您的应用程序没有该权限,这就是您访问被拒绝的原因。

查看 MSDN 文章 ReadProcessMemory 。有一些关于如何获得该特权的社区内容。

关于java - 使用 JNA 获取正在运行的进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16667557/

相关文章:

delphi - BCryptEncrypt 在 AES-GCM 上返回 STATUS_INVALID_PARAMETER

c# - 如何使用 C# 列出可用的视频模式?

c++ - Win32 C++ 在运行时为 MenuItem 分配/更改快捷键

c++ - 限制每个进程的物理内存

c++ - 如何使用fork创建并行子进程

java - 为什么要编译具有此类通用绑定(bind)的代码

java - 平台.runLater

java - SSL 如何保护数据免遭嗅探?

Java native 进程库

java - 如何正确实现onFling方法?