Heim >Backend-Entwicklung >Golang >Warum schlägt mein Go WebSocket mit dem mod_proxy_wstunnel von Apache fehl (403/400-Fehler)?

Warum schlägt mein Go WebSocket mit dem mod_proxy_wstunnel von Apache fehl (403/400-Fehler)?

Linda Hamilton
Linda HamiltonOriginal
2025-01-05 12:16:39673Durchsuche

Why is my Go WebSocket failing with Apache's mod_proxy_wstunnel (403/400 Errors)?

Fehlerbehebung bei WebSocket hinter Apache mit mod_proxy_wstunnel

Diese Frage zielt darauf ab, Probleme bei der Verwendung von go-websocket hinter Apache mit mod_proxy_wstunnel zu beheben. Beim Versuch, eine Verbindung über den WebSocket herzustellen, sind beim Autor die Fehler 403 Forbidden und 400 Bad Request aufgetreten.

Um das Problem zu beheben, hat der Autor die folgenden Schritte ausgeführt:

  1. Nachgestellter Schrägstrich hinzugefügt zum WebSocket-Pfad: Laut Aralo ist das Hinzufügen eines abschließenden Schrägstrichs zum WebSocket-Pfad von entscheidender Bedeutung damit Apache es als GET-Anfrage erkennt.
  2. Korrekte Reihenfolge der ProxyPass-Direktiven: Wie James Henstridge vorgeschlagen hat, muss die für den WebSocket-Pfad spezifische ProxyPass-Direktive vor der Root-ProxyPass-Direktive platziert werden.
  3. Ursprungsprüfung entfernen: Der Go-Websocket-Chat-Beispielcode enthält eine Ursprungsprüfung im ServeWs()-Funktion, die die Verbindung verhindert hat. Diese Prüfung wurde entfernt.

Nach der Implementierung dieser Änderungen berichtet der Autor, dass der WebSocket nun wie erwartet funktioniert.

Darüber hinaus kann das Lesen von Apache-Protokollen, wie von Covener empfohlen, hilfreich sein wertvolle Einblicke in das Thema.

Das obige ist der detaillierte Inhalt vonWarum schlägt mein Go WebSocket mit dem mod_proxy_wstunnel von Apache fehl (403/400-Fehler)?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn