在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中文網其他相關文章!