假裝成為TTY:深入研究
程式設計中遇到的常見挑戰之一是處理歧視輸入來源的程式(如stdin)基於它們是終端機(TTY) 還是管道。為了解決這個問題,您可能需要讓您的程式假裝成 TTY。在本文中,我們將探討如何使用獨立的二進位程式在 Linux 和 macOS 中實現這一目標,主要專注於 Go。
假裝成 TTY 的關鍵思想是創建一個偽終端(也稱為偽終端)。稱為 pty)。 pty 是一個虛擬終端,其行為類似於常規終端,但它實際上是作為一對文件描述符實現的。這些檔案描述符之一用於從 pty 讀取輸入,而另一個用於將輸出寫入其中。
以下 Go 程式碼提供如何建立 pty並在其中運行命令的範例,捕獲其輸出:
package main import ( "io" "log" "os" "os/exec" "runtime" ) func main() { // Get the current operating system. osName := runtime.GOOS // Create a master pty. master, err := os.OpenFile("/dev/ptmx", os.O_RDWR, 0) if err != nil { log.Fatal(err) } // Get the slave pty name. slaveName, err := ptsname(master) if err != nil { log.Fatal(err) } // Fork a child process. child, err := os.ForkExec("/bin/sh", []string{"sh", "-c", "ls -la"}, nil, slaveName, master, master) if err != nil { log.Fatal(err) } // Close the master pty. master.Close() // Read output from the slave pty. buf := make([]byte, 1024) for { n, err := os.Read(child, buf) if err == io.EOF { break } if err != nil { log.Fatal(err) } if osName == "linux" { // Remove carriage return (CR) characters. buf = buf[:n-1] } os.Stdout.Write(buf) } // Wait for the child process to exit. child.Wait() }
可以使用以下命令將此程式碼編譯為獨立的二進位檔案:
go build -o ttypretend main.go
一次編譯完成後,可以如下執行程式:
./ttypretend
並且會輸出目前目錄的內容。
以上是如何讓我的程式在 Linux 和 macOS 中偽裝成 TTY?的詳細內容。更多資訊請關注PHP中文網其他相關文章!