在 Go 中将 HTTP 重定向到 HTTPS
本文解决了在 Go 应用程序中将 HTTP 流量重定向到 HTTPS 的问题。尽管成功设置了 TLS,了解如何有效地实现此重定向至关重要。
建立重定向处理程序
要启动重定向,请创建一个处理重定向的处理程序到 HTTPS。下面是一个示例:
func redirectToTls(w http.ResponseWriter, r *http.Request) { http.Redirect(w, r, "https://IPAddr:443"+r.RequestURI, http.StatusMovedPermanently) }
此处理程序将使用 IP 地址和端口 443 将 HTTP 请求重定向到相应的 HTTPS 对应项。
重定向 HTTP 流量
一旦建立了重定向处理程序,就需要将传入的 HTTP 流量重定向到它。这可以通过启动一个监听 80 端口并为重定向处理程序提供服务的 goroutine 来实现:
go func() { if err := http.ListenAndServe(":80", http.HandlerFunc(redirectToTls)); err != nil { log.Fatalf("ListenAndServe error: %v", err) } }()
这个 goroutine 将持续监听 80 端口并将任何传入的 HTTP 请求重定向到 HTTPS,有效确保所有流量已加密。
以上是如何在 Go 中高效地将 HTTP 重定向到 HTTPS?的详细内容。更多信息请关注PHP中文网其他相关文章!