1 回答

TA貢獻1982條經驗 獲得超2個贊
正如 的Hijacker
文檔所說
劫持讓呼叫者接管連接。在調用 Hijack 之后,HTTP 服務器庫將不會對連接執行任何其他操作。
管理和關閉連接成為呼叫者的責任。
返回的 net.Conn 可能已經設置了讀取或寫入的最后期限,具體取決于服務器的配置。調用者有責任根據需要設置或清除這些截止日期。
返回的 bufio.Reader 可能包含來自客戶端的未處理的緩沖數據。
調用 Hijack 后,不得使用原始 Request.Body。原始 Request 的 Context 保持有效并且不會被取消,直到 Request 的 ServeHTTP 方法返回。
您需要寫信給c
而不是buf
. 并且您需要編寫響應狀態和Content-Length
標題。
http.HandleFunc("/", func(writer http.ResponseWriter, request *http.Request) {
fmt.Println("start")
writer.Header().Add("Content-Length", "5")
writer.WriteHeader(200)
hj, ok := writer.(http.Hijacker)
fmt.Println(ok)
c, _, err := hj.Hijack()
if err != nil {
panic(err)
}
n, err := c.Write([]byte("hello"))
if err != nil {
panic(err)
}
fmt.Println("n == ",n)
err = c.Close()
if err != nil {
panic(err)
}
fmt.Println("end")
})
- 1 回答
- 0 關注
- 220 瀏覽
添加回答
舉報