亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何獲取子進程的句柄 uintptr?

如何獲取子進程的句柄 uintptr?

Go
陪伴而非守候 2022-09-05 15:30:50
我想啟動一個子進程(我在Windows 10上),我希望能夠隨意暫停和恢復該進程。我發現這個整潔的未記錄的Windows功能應該可以完成這項工作,但現在我需要獲得進程的句柄來發出掛起命令。NtSuspendProcessntdll.dll這是一個例子:modntdll = syscall.NewLazyDLL("ntdll.dll")procNtSuspendProcess = modntdll.NewProc("NtSuspendProcess")procNtResumeProcess  = modntdll.NewProc("NtResumeProcess")_, _, err = procNtSuspendProcess.Call(uintptr(handle))_, _, err = procNtResumeProcess.Call(uintptr(handle))要啟動該過程,我通常會使用該函數,但我找不到檢索該過程句柄的方法。exec.Command有沒有辦法在啟動流程時獲取句柄?如果不是 ,我應該使用哪個其他庫來啟動同時返回進程句柄的進程?exec.Command作為旁注:我已經研究了syscall。StartProcess,但它的級別很低,我覺得無法處理這樣的原始實現。_, handle, err := syscall.StartProcess("C:\\WINDOWS\\system32\\cmd.exe", []string{}, procAttr)
查看完整描述

2 回答

?
梵蒂岡之花

TA貢獻1900條經驗 獲得超5個贊

Go 不會公開中的句柄,您將不得不通過它來訪問它。exec.Command


反射


cmd := exec.Command("cmd.exe")

cmd.Start()

handle := uintptr(reflect.ValueOf(cmd.Process).Elem().FieldByName("handle").Uint())

或者通過創建相同的“進程”類型并將 Cmd.Process 強制轉換為您自己的類型以訪問私有字段。


type Process struct {

   Pid int

   handle uintptr

   isdone uint32

   sigMu sync.RWMutex

}

cmd := exec.Command("cmd.exe")

cmd.Start()

proc := (*Process)(unsafe.Pointer(cmd.Process))

println(proc.handle)


查看完整回答
反對 回復 2022-09-05
?
富國滬深

TA貢獻1790條經驗 獲得超9個贊

“Make that 4”的答案都是完美的,簡單而解釋得很好。


我只是添加一個我發現的其他方法,只是為了完整性(需要導入)

更新:顯然這種方法可能會導致錯誤/錯誤,最好不要實現它(檢查注釋)golang.org/x/sys/windows


cmd := exec.Command("cmd.exe")

cmd.Start()


// using PROCESS_SUSPEND_RESUME since I want to call NtSuspendProcess function

handle, _ := windows.OpenProcess(windows.PROCESS_SUSPEND_RESUME, false, uint32(cmd.Process.Pid))

defer windows.CloseHandle(handle)


fmt.Println(handle)


查看完整回答
反對 回復 2022-09-05
  • 2 回答
  • 0 關注
  • 108 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號