awalol

awalol

github

Kotlin/Native 讀取進程內存

主要步驟#

  1. 通過 CreateToolhelp32Snapshot 遍歷進程並獲取進程 id

代碼#

private fun getProcessID(processName: String): UInt{
    memScoped {
        val snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS.toUInt(),0U)
        val processEntry = alloc<PROCESSENTRY32W>()
        processEntry.dwSize = sizeOf<PROCESSENTRY32W>().convert()
        if(Process32FirstW(snapshot,processEntry.ptr) != 0){
            do {
                val name = processEntry.szExeFile.toKString()
                if(processName == name){
                    CloseHandle(snapshot)
                    return processEntry.th32ProcessID
                }
            }while (Process32NextW(snapshot,processEntry.ptr) != 0)
        }
        CloseHandle(snapshot)
        return 0U
    }
}

遇到的坑#

1. 沒有 CreateToolhelp32Snapshot 方法#

原因:#

預設沒有導入 tlhelp32.h 頭文件

解決辦法:#

  1. 創建路徑 nativeInterop/cinterop 並放入 windows.def :
package = platform.windows
headers = wtypes.h minwindef.h windows.h commctrl.h dwmapi.h shlobj.h shlwapi.h shobjidl.h \
    urlmon.h usp10.h uxtheme.h vfw.h wininet.h winsock2.h ws2tcpip.h ws2def.h windows.h tlhelp32.h
compilerOpts = -DUNICODE -DWINVER=0x0601 -D_WIN32_WINNT=0x0601 -DWINAPI_FAMILY=3 -DOEMRESOURCE \
    -Wno-incompatible-pointer-types -Wno-deprecated-declarations
linkerOpts = -lcomctl32 -lcrypt32 -lshlwapi -lshell32 -limm32 -lusp10 -lwininet -lgdi32 -luser32 -lkernel32 -lbcrypt -luuid -ldwmapi
noStringConversion = LoadCursorA LoadBitmapA LoadIconA LoadImageA LoadCursorW LoadBitmapW LoadIconW LoadImageW
depends = posix

路徑圖 :

image-20230812153025075

windows.def 的來源:#

windows.def 在此文件的 headers 後 加入 windows.h tlhelp32.h

  1. build.gradle.kts 加入:

    compilations.getByName("main"){
        cinterops{
            val windows by creating
        }
    }
    

image-20230812153647319

:::

2. 獲取不到進程#

原先使用的是 Process32FirstProcess32Next 這兩個方法去處理 CreateToolhelp32SnapshotProcess32First 的得到的結果為 0,正常來講不應該為 0。隨後我在 YouTrack 發了Issue

得到的解決辦法是更換方法:

  • PROCESSENTRY32 -> PROCESSENTRY32W

  • Process32First -> Process32FirstW

  • Process32Next -> Process32NextW

在此感謝幾位工作人員幫忙解決問題

參考文章#

Create an app using C Interop and libcurl
[Kotlin/Native] Unable to get process via CreateToolhelp32Snapshot

載入中......
此文章數據所有權由區塊鏈加密技術和智能合約保障僅歸創作者所有。