HTTP/2 ist definitiv der Trend der Zukunft, weil es jetzt der Standard des HTTP-Protokolls ist. Wie wir in Can I use sehen können, unterstützen 70,15 Prozent der Browser das HTTP/2. Aber HTTP/2 ist so neu, dass es Browser gibt, die nur HTTP/1.x unterstützen, und es gibt viele Server, die nur HTTP/1.x unterstützen. Ich wusste, dass ein Client den HTTP-Aktualisierungsmechanismus verwenden kann, um ein geeignetes Protokoll für die Kommunikation mit dem Server auszuhandeln. Wenn der Server beispielsweise HTTP/2 unterstützt, wechselt das Kommunikationsprotokoll zu HTTP/2, andernfalls wird HTTP/1.x verwendet. Aber das gilt nur für die Beziehung, in der der Browser die verwendeten Clients sowohl HTTP/2 als auch HTTP/1.x unterstützt, oder?Was passiert, wenn ein HTTP/1.1-Client mit einem HTTP/2-Server kommuniziert und was passiert, wenn ein HTTP/2-Client mit einem HTTP/1.1-Server kommuniziert?
Aber was passiert, wenn ein Benutzer in einem Browser, der nur HTTP/1.x unterstützt, mit einem HTTP/2-Server kommunizieren möchte? Wird der Server die Anfrage ignorieren oder einen Fehler an den Benutzer zurücksenden?
Und was ist, wenn ein Benutzer auf einem Browser, der nur HTTP/2 unterstützt, mit HTTP/1.1 nur Server kommunizieren möchte? Ich denke, der Prozess könnte so gehen: Der Benutzer sendet eine Verbindung Vorwort an den Server, der Server kann die Anfrage nicht erkennen, so dass der Benutzer eine Verbindung Fehlermeldung erhalten. Ist das richtig?
Oder gibt es einen Browser, der nur HTTP/2 unterstützt?
Um wie beschrieben arbeiten zu können, muss der Server https unterstützen? Was ist, wenn der Server https nicht unterstützt? – user3744927
@ user3744927: Hinzufügen von Unterstützung von HTTPS und tunen es - es ist der erste Schritt der Implementierung von HTTP/2. Man kann jetzt ein SSL/TLS-Zertifikat ** kostenlos ** erhalten, zum Beispiel von https://letsencrypt.org/, https://startssl.com/ oder anderen. Die Lösung von https://letsencrypt.org/ ist die einfachste und mächtigste. Welches Betriebssystem verwenden Sie und welchen Webserver? Ich würde Ihnen empfehlen, OpenSSL zu installieren und das Zertifikat von Let's encrypt zu erhalten. Dann konfigurieren Sie Ihren Server basierend auf [die Vorschläge] (https://mozilla.github.io/server-side-tls/ssl-config-generator/) – Oleg
Ich bin nicht implementieren HTTP/2 Server, ich bin neugierig HTTP/2 Rückwärtskompatibilität. Die meisten Browser unterstützen nur HTTP/2 über TLS, aber es gibt immer noch eine große Anzahl von Servern, die keine Verschlüsselung unterstützen. Und was ist, wenn einige Server in HTTP/2 immer noch keine Verschlüsselung bevorzugen? – user3744927