Sec-WebSocket-Accept
Der HTTP Sec-WebSocket-Accept Response-Header wird beim WebSocket Eröffnungshandshake verwendet, um anzuzeigen, dass der Server bereit ist, zu einer WebSocket-Verbindung aufzurüsten.
Dieser Header darf höchstens einmal in der Antwort erscheinen und hat einen Direktivenwert, der aus dem Sec-WebSocket-Key
Anfrage-Header berechnet wird, der in der entsprechenden Anfrage gesendet wurde.
Header-Typ | Response-Header |
---|---|
Verbotener Header-Name | Ja (Sec- Präfix) |
Syntax
Sec-WebSocket-Accept: <hashed key>
Direktiven
<hashed key>
-
Wenn ein
Sec-WebSocket-Key
Header angegeben wurde, wird der Wert dieses Headers berechnet, indem der Wert des Schlüssels genommen, die Zeichenkette258EAFA5-E914-47DA-95CA-C5AB0DC85B11
daran angehängt und der SHA-1 Hash dieser zusammengefügten Zeichenkette ermittelt wird — was einen 20-Byte Wert ergibt. Dieser Wert wird dann base64 kodiert, um den Wert dieser Eigenschaft zu erhalten.
Beispiele
WebSocket Eröffnungshandshake
Der Client wird ein WebSocket-Handshake mit einer Anfrage wie der folgenden initiieren. Beachten Sie, dass dies als HTTP GET
-Anfrage (HTTP/1.1 oder höher) beginnt und den Upgrade
Header enthält, der die Absicht signalisiert, zu einer WebSocket-Verbindung aufzurüsten. Er enthält auch Sec-WebSocket-Key
, der in die Berechnung von Sec-WebSocket-Accept
einfließt, um die Absicht, die Verbindung zu einer WebSocket-Verbindung aufzurüsten, zu bestätigen.
GET /chat HTTP/1.1
Host: example.com:8000
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: dGhlIHNhbXBsZSBub25jZQ==
Sec-WebSocket-Version: 13
Die Antwort des Servers sollte den Sec-WebSocket-Accept
Header mit einem Wert enthalten, der aus dem Sec-WebSocket-Key
Header in der Anfrage berechnet wurde und die Absicht, die Verbindung zu einer WebSocket-Verbindung aufzurüsten, bestätigt:
HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept: s3pPLMBiTxaQ9kYGzzhZRbK+xOo=
Spezifikationen
Specification |
---|
Unknown specification # section-11.3.3 |
Browser-Kompatibilität
BCD tables only load in the browser