亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何使用 Server.TLSNextProto 禁用 HTTP/2

如何使用 Server.TLSNextProto 禁用 HTTP/2

Go
臨摹微笑 2023-07-26 16:37:02
我有一個處理 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


查看完整回答
反對 回復 2023-07-26
  • 1 回答
  • 0 關注
  • 174 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號