php-Editor Strawberry ist sich der Bedeutung des Routings bei der Lösung des Go-Proxy-Fehlerproblems bewusst. Routing ist ein Kernkonzept der Netzwerkkommunikation, das bestimmt, wie Datenpakete von der Quelladresse zur Zieladresse übermittelt werden sollen. Wenn Sie die Go-Sprache zum Proxying verwenden, ist es sehr wichtig, das Routing richtig zu konfigurieren. Durch ein tiefes Verständnis der Routing-Prinzipien und der damit verbundenen Konfigurationen können wir das Problem des Go-Proxy-Ausfalls effektiv lösen und die Stabilität und Zuverlässigkeit der Netzwerkkommunikation sicherstellen. In diesem Artikel stellen wir das Funktionsprinzip des Routings und gängige Konfigurationsmethoden vor, um jedem zu helfen, die Routing-Technologie besser zu verstehen und anzuwenden.
Ich habe einen einfachen Go-Proxy wie diesen. Ich möchte Anfragen darüber weiterleiten und die Antworten einiger Websites ändern. Die Seiten laufen über TLS, aber mein Proxy ist nur ein lokaler Server.
func main() { target, _ := url.parse("https://www.google.com") proxy := httputil.newsinglehostreverseproxy(target) proxy.modifyresponse = rewritebody http.handle("/", proxy) http.listenandserve(":80", proxy) }
Ergebnis: 404-Fehler, wie unten gezeigt:
Soweit ich weiß, initiiert der Proxyserver die Anfrage, schließt sie und gibt dann eine geänderte Antwort zurück. Ich bin mir nicht sicher, ob es hier scheitern wird. Fehlt mir etwas zum Weiterleiten von Headern, an die diese Anfrage fehlschlägt?
Ich habe das Routing funktioniert. Anfangs war ich daran interessiert, die Antwort zu ändern, konnte aber außer dem magical
-Header keine Änderungen feststellen.
func modifyResponse() func(*http.Response) error { return func(resp *http.Response) error { resp.Header.Set("X-Proxy", "Magical") b, _ := ioutil.ReadAll(resp.Body) b = bytes.Replace(b, []byte("About"), []byte("Modified String Test"), -1) // replace html body := ioutil.NopCloser(bytes.NewReader(b)) resp.Body = body resp.ContentLength = int64(len(b)) resp.Header.Set("Content-Length", strconv.Itoa(len(b))) resp.Body.Close() return nil } } func main() { target, _ := url.Parse("https://www.google.com") proxy := httputil.NewSingleHostReverseProxy(target) director := proxy.Director proxy.Director = func(r *http.Request) { director(r) r.Host = r.URL.Hostname() } proxy.ModifyResponse = modifyResponse() http.Handle("/", proxy) http.ListenAndServe(":80", proxy) }
Das Hauptproblem wird in der Dokumentation erwähnt, aber aus der Dokumentation geht nicht klar hervor, wie genau damit umgegangen werden soll:
newsinglehostreverseproxy schreibt den Host-Header nicht neu. umschreiben Host-Header, verwenden Sie Reverseproxy direkt mit einer benutzerdefinierten Director-Richtlinie.
https://www.php.cn/link/747e32ab0fea7fbd2ad9ec03daa3f840
Sie verwenden die reverseproxy
。您仍然可以使用 newsinglehostreverseproxy
并调整 director
-Funktion nicht direkt, also so:
func main() { target, _ := url.Parse("https://www.google.com") proxy := httputil.NewSingleHostReverseProxy(target) director := proxy.Director proxy.Director = func(r *http.Request) { director(r) r.Host = r.URL.Hostname() // Adjust Host } http.Handle("/", proxy) http.ListenAndServe(":80", proxy) }
Das obige ist der detaillierte Inhalt vonDer Go-Proxy schlägt beim Lernen von Routen fehl. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!