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 关注
- 101 浏览
添加回答
举报