gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 15:10:51 25 4
gpt4 key购买 nike

我有一个处理 https 请求的 Go 服务器:

package main
import (
"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协议(protocol)有透明的支持。我们有一些客户端在 HTTP/2 中行为明显错误,因此我们需要在服务器端禁用 HTTP/2。

不幸的是,我无法使用 ENV 变量 GODEBUG=http2server=0 禁用 HTTP/2。剩下的是 Server.TLSNextProto,如文档 here 所示。 。

如何在上面的服务器代码上使用 Server.TLSNextProto 来禁用 https/2?

最佳答案

禁用 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

关于go - 如何使用 Server.TLSNextProto 禁用 HTTP/2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58088956/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com