我有一個處理 https 請求的 Go 服務器:package mainimport ( "fmt" "net/http" "log")const ( port = "5966" cert = "/tmp/cert.pem" key = "/tmp/key.pem")func main() { listen_at := ":" + port fmt.Println("Listening at", listen_at) go http.HandleFunc("/job_handler/", job_handler) log.Fatal(http.ListenAndServeTLS(listen_at, cert, key, nil))}func job_handler(w http.ResponseWriter, r *http.Request) { // do somework}事實證明,在 https 模式下,Go 對 HTTP/2 協議有透明的支持。我們有一些客戶端在 HTTP/2 中行為明顯錯誤,因此我們需要在服務器端禁用 HTTP/2。不幸的是,我無法使用 ENV 變量GODEBUG=http2server=0來禁用 HTTP/2。剩下的內容Server.TLSNextProto如此處記錄的那樣。如何Server.TLSNextProto在我的服務器代碼上使用上面的代碼來禁用 https/2?
1 回答

隔江千里
TA貢獻1906條經驗 獲得超10個贊
禁用 HTTP/2 的最簡單設置是
package main
import (
"log"
"net/http"
"crypto/tls"
)
func main() {
m := http.NewServeMux()
srv := &http.Server{
Handler: m,
Addr: "127.0.0.1:8080",
TLSNextProto: make(map[string]func(*http.Server, *tls.Conn, http.Handler)),
}
log.Fatal(srv.ListenAndServe())
}
您可以通過以下方式驗證支持
curl -v --http2-prior-knowledge http://localhost:8080
- 1 回答
- 0 關注
- 174 瀏覽
添加回答
舉報
0/150
提交
取消