1 回答

TA貢獻1811條經驗 獲得超4個贊
您可以劫持連接以訪問底層的 tcp 連接。它由 golang 中的標準 http 服務器支持。
以下是文檔中的示例。您可以直接調用并返回,而不是像本例
中那樣做,這將斷開連接。defer conn.Close()conn.Close()
請記住,此時連接已被接受。如果你甚至不想接受連接,你需要實現一個自定義的 tcp 偵聽器,有條件地將流量路由到你的 http 服務器。您還必須考慮您的情況?;蛘呃纾欠裥枰獜?http 請求中讀取任何內容以確定您的條件的結果?
http.HandleFunc("/hijack", func(w http.ResponseWriter, r *http.Request) {
hj, ok := w.(http.Hijacker)
if !ok {
http.Error(w, "webserver doesn't support hijacking", http.StatusInternalServerError)
return
}
conn, bufrw, err := hj.Hijack()
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
// Don't forget to close the connection:
defer conn.Close()
bufrw.WriteString("Now we're speaking raw TCP. Say hi: ")
bufrw.Flush()
s, err := bufrw.ReadString('\n')
if err != nil {
log.Printf("error reading string: %v", err)
return
}
fmt.Fprintf(bufrw, "You said: %q\nBye.\n", s)
bufrw.Flush()
})
完整文檔: https ://pkg.go.dev/net/http#Hijacker
- 1 回答
- 0 關注
- 122 瀏覽
添加回答
舉報