Update VMess protocol to allow streaming data

pull/298/head
V2Ray 9 years ago
parent 7341e7e70a
commit 7c20b392d4

@ -3,40 +3,40 @@
* 版本1 * 版本1
## 数据请求 ## 数据请求
版本部分:
* 1 字节:版本号,目前为 0x1 * 1 字节:版本号,目前为 0x1
认证部分:
* 16 字节md5(用户 VID + 'ASK') * 16 字节md5(用户 VID + 'ASK')
* 1 字节:余下字节数 L 指令部分:
* 1 字节:随机填充长度 M (M <= 32) * 2 字节:随机填充长度 M (M <= 32)
* M 字节:随机填充内容 * M 字节:随机填充内容
* 32 字节:应答所使用的 AES Key AK * 1 字节:保留,总是 0x00
* 1 字节:保留 * 16 字节:请求数据 IV
* X 字节:实际请求内容 * 16 字节:响应数据 IV
* 16 字节IV * 1 字节:指令
* 1 字节:指令 * 0x00保留
* 0x0保留 * 0x01TCP 请求
* 0x1TCP 请求 * 0x02UDP 请求
* 0x2UDP 请求 * 2 字节:目标端口
* 2 字节:目标端口 * 1 字节:目标类型
* 1 字节:目标类型 * 0x01IPv4
* 0x01IPv4 * 0x02域名
* 0x02域名 * 0x03IPv6
* 0x03IPv6 * 目标地址:
* 目标地址: * 4 字节IPv4
* 4 字节IPv4 * 2 字节长度 + 域名
* 2 字节长度 + 域名 * 16 字节IPv6
* 16 字节IPv6 数据部分
* 4 字节:请求长度 N
* N 字节:请求数据 * N 字节:请求数据
其中第 18 字节开始所有内容经过 AES-256 加密Key 为 left(用户 VID, 32)。 其中指令部分经过 AES-256 加密Key 为 left(用户 VID, 32);数据部分使用块密码加密
## 数据应答 ## 数据应答
版本部分:
* 1 字节:版本号,目前为 0x1 * 1 字节:版本号,目前为 0x1
认证部分:
* 16 字节md5(用户 VID + 'ANS') * 16 字节md5(用户 VID + 'ANS')
* 1 字节:余下字节数 L 数据部分
* L 字节 * N 字节:应答数据
* 16 字节IV
* 1 字节:数据长度
* N 字节:应答数据
其中第 18 字节开始所有内容经过 AES-256 加密Key 为 AK。 其中数据部分使用块密码加密
Loading…
Cancel
Save