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 중국어 웹사이트의 기타 관련 기사를 참조하세요!