11.1.注册新的URI模式
11.1.1.注册“ws“模式
一个|ws| URI标识一个WebSocket服务器和资源名称。
URI模式名称
ws
状态
永久的
URI模式语法
使用ABNF[RFC5234]语法和URI规范[RFC3986]的ABNF终结符:
"ws:" "//" authority path-abempty [ "?" query ]
和 [RFC3986]组件形成的资源名发生给服务器来确定服务期望的类型。其他组件的含义描述在[RFC3986]。
模式语义
这个模式的作用仅是使用WebSocket协议打开一个连接。
编码考虑
上边定义的语法不包括host组件中的字符,必须按照[RFC3987]从Unicode转换为ASCII或其替换。为了模式标准化的目的,国际化域名(IDN)形式的host组件和它们转换的域名代码(Punycode)被认为是等价的(参考[RFC3987] 5.3.3节)。
上边定义的语法不包括其他组件中的字符,必须按照定义在URI[RFC3986] 和国际化资源标识符(IRI)[RFC3987]规范从Unicode编码转换为ASCII,通过首先编码字符为UTF-8,接着使用它们百分数编码的形式替换相应的字节。
应用/协议使用这个URI模式命名
WebSokcet协议
互操作性考虑
使用WebSocket需要使用HTTP版本1.1或更高。
安全考虑
参考“安全考虑”章节。
联系方式
HYBI WG [email protected]
作者/变更管理员
IETF [email protected]
参考资源
11.1.2.注册”wss“模式
一个|wss| URI标识一个WebSocket服务器和资源名称,并表明在受TLS保护的连接之上通信(包括标准的TLS的好处,比如数据保密性和完整性和端点认证)。
URI模式名称
wss
状态
永久的
URI模式语法
使用ABNF[RFC5234]语法和URI规范[RFC3986]的ABNF终结符:
"wss:" "//" authority path-abempty [ "?" query ]
和 [RFC3986]组件形成的资源名发生给服务器来确定服务期望的类型。其他组件的含义描述在[RFC3986]。
URI模式语义
这个模式的作用仅是使用WebSocket协议打开一个使用TLS的连接。
编码考虑
上边定义的语法不包括host组件中的字符,必须按照[RFC3987]从Unicode转换为ASCII或其替换。为了模式标准化的目的,国际化域名(IDN)形式的host组件和它们转换的域名代码(Punycode)被认为是等价的(参考[RFC3987] 5.3.3节)。
上边定义的语法不包括其他组件中的字符,必须按照定义在URI[RFC3986] 和国际化资源标识符(IRI)[RFC3987]规范从Unicode编码转换为ASCII,通过首先编码字符为UTF-8,接着使用它们百分数编码的形式替换相应的字节。
应用/协议使用这个URI模式命名
TLS之上的WebSokcet协议
互操作性考虑
使用WebSocket需要使用HTTP版本1.1或更高。
安全考虑
参考“安全考虑”章节。
联系方式
HYBI WG [email protected]
作者/变更管理员
IETF [email protected]
参考资源
11.2.注册”WebSocket“ HTTP Upgrade关键字
本节按照RFC2817[RFC2817]定义了在HTTP Upgrade符号注册中心中注册一个关键字。
符号名称
WebSocket
作者/变更管理员
IETF [email protected]
参考资源
11.3.注册新的HTTP头字段
11.3.1. Sec-WebSocket-Key
本节描述了在永久消息头字段命名注册中心[RFC3864]中注册一个头字段。
头字段名
Sec-WebSocket-Key
适用协议
http
状态
标准的
作者/变更管理员
IETF
参考资源
相关信息
该头字段仅用于WebSocket打开阶段握手。
|Sec-WebSocket-Key| 头字段用于WebSocket打开阶段握手。它从客户端发送到服务器,提供部分信息用于服务器检验它收到了一个有效的WebSocket握手。这有助于确保服务器不接收正被滥用来发送数据给毫不知情的WebSocket服务器的非WebSocket客户端的连接(例如HTTP客户端)。
|Sec-WebSocket-Key| 头字段在一个HTTP请求中不能出现多于一个。
11.3.2. Sec-WebSocket-Extensions
本节描述了在永久消息头字段命名注册中心[RFC3864]中注册一个头字段。
头字段名
Sec-WebSocket-Extensions
适用协议
http
状态
标准的
作者/变更管理员
IETF
参考资源
相关信息
该头字段仅用于WebSocket打开阶段握手。
|Sec-WebSocket-Extensions|头字段用于WebSocket打开阶段握手。它最初是从客户端发送到服务器,随后从服务器端发送到客户端,用来达成在整个连接阶段的一组协议级扩展。
|Sec-WebSocket-Extensions|头字段在HTTP请求中可以出现多次(逻辑上等价于单个|Sec-WebSocket-Extensions|头字段包含所有值)。
但是,|Sec-WebSocket-Extensions|头字段在一个HTTP响应中必须不出现多于一次。
11.3.3. Sec-WebSocket-Accept
本节描述了在永久消息头字段命名注册中心[RFC3864]中注册一个头字段。
头字段名
Sec-WebSocket-Accept
适用协议
http
状态
标准的
作者/变更管理员
IETF
参考资源
规范文档
相关信息
该头字段仅用于WebSocket打开阶段握手。
| Sec-WebSocket-Accept|头字段用于WebSocket打开阶段握手。它从服务器发送到客户端来确定服务器愿意启动WebSocket连接。
|Sec-WebSocket-Accept| 头在一个HTTP响应中必须不出现多于一次。
11.3.4. Sec-WebSocket-Protocol
本节描述了在永久消息头字段命名注册中心[RFC3864]中注册一个头字段。
头字段名
Sec-WebSocket-Protocol
适用协议
http
状态
标准的
作者/变更管理员
IETF
参考资源
规范文档
相关信息
该头字段仅用于WebSocket打开阶段握手。
|Sec-WebSocket-Protocol|头字段用于WebSocket打开阶段握手。它从客户端发送到服务器端,并从服务器端发回到客户端来确定连接的子协议。这使脚本可以选择一个子协议和确定服务器同意服务子协议。
|Sec-WebSocket-Protocol|头字段在一个HTTP请求中可以出现多次(逻辑上等价于单个|Sec-WebSocket-Protocol|头字段包含所有值)。
但是,|Sec-WebSocket-Protocol|头字段在一个HTTP响应中必须不出现多于一次。
11.3.5.Sec-WebSocket-Version
本节描述了在永久消息头字段命名注册中心[RFC3864]中注册一个头字段。
头字段名
Sec-WebSocket-Version
适用协议
http
状态
标准的
作者/变更管理员
IETF
参考资源
规范文档
相关信息
该头字段仅用于WebSocket打开阶段握手。
|Sec-WebSocket- Version |头字段用于WebSocket打开阶段握手。它从客户端发送到服务器端来指定连接的协议版本。这能使服务器正确解释打开阶段握手和发送数据的随后数据,如果服务器不能以安全的方式解释数据则关闭连接。当从客户端接收到不匹配服务器端理解的版本时,WebSocket握手错误,|Sec-WebSocket-Version|头字段也从服务器端发送到客户端。在这种情况下,头字段包括服务器端支持的协议版本。
注意,如果没有期望更高版本号,必然是向下兼容低版本号。
|Sec-WebSocket-Version|头字段在一个HTTP响应中可以出现多次(逻辑上等价于单个|Sec-WebSocket-Version|透过自动包含所有值)。
但是,|Sec-WebSocket-Version|头字段在HTTP请求中必须不出现多于一次。
11.4.WebSocket扩展名注册
本规范依据RFC5226[RFC5226]陈述的原则,创建了一个新的IANA注册用于与WebSocket协议一起使用的WebSocket扩展名。
作为本注册的一部分,IANA维护以下信息:
扩展标识符
扩展标识符, 将被用在注册到本规范11.3.2节的| Sec-WebSocket-Extensions|头字段。其值必须符合定义在本规范9.1节的扩展-符号要求。
扩展通用名称
扩展名称,通常称为扩展。
扩展定义
在扩展用于的WebSocket协议中定义了文档参考。
已知的不兼容扩展
与此扩展是不兼容的一个扩展标识符列表。
WebSocket扩展名受制于“先来先服务”的IANA注册策略 [RFC5226]。
在此注册中心没有初始值。
11.5.WebSocket子协议名注册
本规范依据RFC5226[RFC5226]陈述的原则,创建了一个新的IANA注册用于与WebSocket协议一起使用的WebSocket子协议名。
作为本注册的一部分,IANA维护以下信息:
子协议标识符 子协议标识符, 将被用在注册到本规范11.3.4节的|Sec-WebSocket-Protocol|头字段。其值必须符合定义在本规范4.1节给出的第10条的符号要求——也就是,其值必须是RFC5226 [RFC5226].定义的一个符号。
子协议通用名称
子协议名称,通常成为子协议。
子协议定义
在子协议用于的WebSocket协议中定义了文档参考。
WebSocket子协议名受制于“先来先服务”的IANA注册策略 [RFC5226]。
11.6.WebSocket版本号注册
本规范依据RFC5226[RFC5226]陈述的原则,创建了一个新的IANA注册用于与WebSocket协议一起使用的WebSocket版本号。
作为本注册的一部分,IANA维护以下信息:
版本号
用于|Sec-WebSocket-Version|的版本号指定在本规范4.1节。其值必须是一个在0到255(包括)之间的非负整数。
参考
RFC请求一个新的版本号或带版本号的草案名称(见下文)。
状态
“临时的”或“标准的”。参考下面的说明。
一个版本号被指定为“临时的”或“标准的”。
“标准的”版本号是记录在一个RFC中并用来识别一个主要的、稳定的WebSocket协议版本,例如本RFC定义的版本。“标准的”版本号受制于“IETF评审”IANA注册策略 [RFC5226]。
“Interim”的版本号记录在一个Internet草案中用并用于帮助实现者识别和与部署的WebSocket版本互操作,例如在公布这个RFC之前指定的版本。“临时的”版本号受制于“专家评审”IANA注册策略 [RFC5226],HYBI工作组主 席(或,如果工作组关闭了,IETF应用区域的区域董事)将是初始的指定专家。
IANA 已经添加如下初始值到注册中心:
+--------+-----------------------------------------+----------+
|Version | Reference | Status |
| Number | | |
+--------+-----------------------------------------+----------+
| 0 + draft-ietf-hybi-thewebsocketprotocol-00 | Interim |
+--------+-----------------------------------------+----------+
| 1 + draft-ietf-hybi-thewebsocketprotocol-01 | Interim |
+--------+-----------------------------------------+----------+
| 2 + draft-ietf-hybi-thewebsocketprotocol-02 | Interim |
+--------+-----------------------------------------+----------+
| 3 + draft-ietf-hybi-thewebsocketprotocol-03 | Interim |
+--------+-----------------------------------------+----------+
| 4 + draft-ietf-hybi-thewebsocketprotocol-04 | Interim |
+--------+-----------------------------------------+----------+
| 5 + draft-ietf-hybi-thewebsocketprotocol-05 | Interim |
+--------+-----------------------------------------+----------+
| 6 + draft-ietf-hybi-thewebsocketprotocol-06 | Interim |
+--------+-----------------------------------------+----------+
| 7 + draft-ietf-hybi-thewebsocketprotocol-07 | Interim |
+--------+-----------------------------------------+----------+
| 8 + draft-ietf-hybi-thewebsocketprotocol-08 | Interim |
+--------+-----------------------------------------+----------+
| 9 + Reserved | |
+--------+-----------------------------------------+----------+
| 10 + Reserved | |
+--------+-----------------------------------------+----------+
| 11 + Reserved | |
+--------+-----------------------------------------+----------+
| 12 + Reserved | |
+--------+-----------------------------------------+----------+
| 13 + RFC 6455 | Standard |
+--------+-----------------------------------------+----------+
11.7.WebSocket关闭代码注册
本规范依据RFC5226[RFC5226]陈述的原则,创建了一个新的IANA注册用于WebSocket关闭代码。
作为本注册的一部分,IANA维护以下信息:
状态码 状态码表示一个按照本文档7.4节的WebSocket连接关闭的原因。状态是一个在1000到4999(包括)之间的一个整数数字。
含义
状态码的含义。每一个状态码都必须有唯一的含义。
联系方式
保留状态代码实体的联系方式。
参考
稳定的文档要求状态码并定义它们的含义。在1000-2999范围内的状态码是必须的且推荐的状态码在3000-3999范围内。
WebSocket关闭代码根据它们的范围受不同的注册要求。本协议请求使用的状态码和其后续版本或扩展受制于“标准功能”、“规定要求”(这意味着“指定专家”)或“IESG审查”IANA注册策略中的任何一个,且应该允许在1000-2999范围内。库、框架和应用请求使用的状态码受制于“先来先服务”IANA注册策略且应该允许在3000-3999范围内。4000-4999范围的状态码被指定用于私有使用。请求应该指出他们要求的状态码是用于WebSocket协议(或未来版本的协议)、扩展,或库/框架/应用。
IANA 已经添加如下初始值到注册中心:
|Status Code | Meaning | Contact | Reference |
-+------------+-----------------+---------------+-----------|
| 1000 | Normal Closure | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1001 | Going Away | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1002 | Protocol error | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1003 | Unsupported Data| [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1004 | ---Reserved---- | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1005 | No Status Rcvd | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1006 | Abnormal Closure| [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1007 | Invalid frame | [email protected] | RFC 6455 |
| | payload data | | |
-+------------+-----------------+---------------+-----------|
| 1008 | Policy Violation| [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1009 | Message Too Big | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1010 | Mandatory Ext. | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
| 1011 | Internal Server | [email protected] | RFC 6455 |
| | Error | | |
-+------------+-----------------+---------------+-----------|
| 1015 | TLS handshake | [email protected] | RFC 6455 |
-+------------+-----------------+---------------+-----------|
11.8.WebSocket操作码注册
本规范依据RFC5226[RFC5226]陈述的原则,创建一个新的IANA注册用于WebSocket操作码。
作为本注册的一部分,IANA维护以下信息:
操作码 操作码表示WebSocket帧的帧类型,定义在5.2节。操作码是一个在0到15(包括)之间的整数数字。
含义
状态码值的含义。
参考
规范要求的操作码。
WebSocket状态码受制于“标准功能”IANA注册策略[RFC5226]。
IANA 已经添加如下初始值到注册中心:
|Opcode | Meaning | Reference |
-+--------+-------------------------------------+-----------|
| 0 | Continuation Frame | RFC 6455 |
-+--------+-------------------------------------+-----------|
| 1 | Text Frame | RFC 6455 |
-+--------+-------------------------------------+-----------|
| 2 | Binary Frame | RFC 6455 |
-+--------+-------------------------------------+-----------|
| 8 | Connection Close Frame | RFC 6455 |
-+--------+-------------------------------------+-----------|
| 9 | Ping Frame | RFC 6455 |
-+--------+-------------------------------------+-----------|
| 10 | Pong Frame | RFC 6455 |
-+--------+-------------------------------------+-----------|
11.9.WebSocket帧头位注册
本规范依据RFC5226[RFC5226]陈述的原则,创建了一个新的IANA注册用于WebSocket帧头位(Framing Header Bits)。此注册控制的位分配标记为5.2节的RSV1、RSV2和RSV3。
这些位被保留用于未来版本或本规范的扩展。
WebSocket帧头位分配受制于“标准功能”IANA注册测策略[RFC5226]。