繁体   English   中英

JNA 按名称从进程中获取模块

[英]JNA get module from process by name

我正在寻找一种在 Java 中从 C++ 重写函数的方法,我从进程的名称中获取模块条目。 我在 JNA 方面经验不足,我很难理解指针是如何在 Java 中实现的。 这是我的 C++ 代码。

ULONG GetModule(DWORD th32ProcessID, MODULEENTRY32* Entry, PCWSTR szModule) 
{
    HANDLE hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE, th32ProcessID);

    if (hSnapshot != INVALID_HANDLE_VALUE) 
{
    ULONG dwError = ERROR_NOT_FOUND;

    Entry->dwSize = sizeof(MODULEENTRY32);

    if (Module32FirstW(hSnapshot, Entry))
    {
        do 
        {
            if (!_wcsicmp(Entry->szModule, szModule))
            {
                dwError = NOERROR;
                break;
            }
        } while (Module32NextW(hSnapshot, Entry));
    }

    CloseHandle(hSnapshot);

    return dwError;
   }
   return GetLastError();
}

这是我在 Java 中实现的尝试:

    private Tlhelp32.MODULEENTRY32W findModule(String module) {
    Tlhelp32.MODULEENTRY32W moduleEntry = new Tlhelp32.MODULEENTRY32W.ByReference();

    WinNT.HANDLE snapshot =
            Kernel32.INSTANCE.CreateToolhelp32Snapshot(
                    TH32CS_SNAPMODULE,
                    new WinDef.DWORD(pid)
            );

    if(snapshot != INVALID_HANDLE_VALUE) {
        if(Kernel32.INSTANCE.Module32FirstW(snapshot, moduleEntry)) {
            do {
                if(Arrays.toString(moduleEntry.szModule).equals(module)) {
                    return moduleEntry;
                }
            } while (Kernel32.INSTANCE.Module32NextW(snapshot, moduleEntry));
        }
    }
    return null;
}

它总是返回空值。

我不认为你在这里寻找Arrays.toString 看看它的文档

返回指定数组内容的字符串表示形式。 字符串表示由数组元素的列表组成,用方括号 ("[]") 括起来。 相邻元素由字符“,”(逗号后跟空格)分隔。 元素通过 String.valueOf(char) 转换为字符串。 如果 a 为空,则返回“空”。

因此,例如, { 'h', 'e', 'l', 'l', 'o' }char[]数组将被字符串化为"[h, e, l, l, o]"

由于您只想将该字符数组按原样转换为字符串,请尝试使用String类的构造函数来完成此操作。

if (module.equals(new String(moduleEntry.szModule))) {
    // ...
}

如果您不是在寻找完全匹配,则可以尝试.contains()

另外,请记住像在 C++ 版本中一样使用CloseHandle关闭快照CloseHandle 如果你不关闭句柄,你的方法每次被调用都会泄漏内存。

private Tlhelp32.MODULEENTRY32W findModule(String module) {
    Tlhelp32.MODULEENTRY32W moduleEntry = new Tlhelp32.MODULEENTRY32W.ByReference();

    WinNT.HANDLE snapshot = Kernel32.INSTANCE.CreateToolhelp32Snapshot(
        TH32CS_SNAPMODULE,
        new WinDef.DWORD(pid)
    );

    if (snapshot == INVALID_HANDLE_VALUE) {
        return null;
    }

    Tlhelp32.MODULEENTRY32W match = null;
    if (Kernel32.INSTANCE.Module32FirstW(snapshot, moduleEntry)) {
        do {
            if (module.equals(new String(moduleEntry.szModule))) {
                match = moduleEntry;
                break;
            }
        } while (Kernel32.INSTANCE.Module32NextW(snapshot, moduleEntry));
    }

    Kernel32.INSTANCE.CloseHandle(snapshot);
    return match;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM