1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-03 07:56:42 -05:00
v2fly/spec/vmess.md

75 lines
2.1 KiB
Markdown
Raw Normal View History

2015-09-05 11:48:38 -04:00
# VMess 设计
## 摘要
* 版本1
2015-09-28 09:10:42 -04:00
## TCP
### 数据请求
认证部分:
2015-09-21 18:08:27 -04:00
* 16 字节:基于时间的 hash(用户 [ID](https://github.com/V2Ray/v2ray-core/blob/master/spec/id.md)),见下文
2015-09-07 17:13:55 -04:00
指令部分:
2015-09-14 15:59:52 -04:00
* 1 字节:版本号,目前为 0x1
* 16 字节:请求数据 IV
* 16 字节:请求数据 Key
2015-09-05 17:03:56 -04:00
* 4 字节:认证信息 V
* 1 字节:指令
* 0x00保留
* 0x01TCP 请求
* 0x02UDP 请求
* 2 字节:目标端口
* 1 字节:目标类型
* 0x01IPv4
* 0x02域名
* 0x03IPv6
* 目标地址:
* 4 字节IPv4
* 1 字节长度 + 域名
* 16 字节IPv6
* 4 字节:指令部分前面所有内容的 FNV1a hash
2015-09-07 17:13:55 -04:00
数据部分
2015-09-07 17:13:55 -04:00
* N 字节:请求数据
2015-09-05 11:48:38 -04:00
2015-09-15 12:25:51 -04:00
其中指令部分经过 AES-128-CFB 加密:
* Keymd5(用户 ID + 'c48619fe-8f02-49e0-b9e9-edf763e17e21')
* IVmd5(X + X + X + X)X = []byte(UserHash 生成的时间) (8 字节, Big Endian)
数据部分使用 AES-128-CFB 加密Key 和 IV 在请求数据中
2015-09-05 11:48:38 -04:00
2015-09-28 09:10:42 -04:00
### 数据应答
数据部分
2015-09-17 18:14:17 -04:00
* 4 字节:认证信息 V
* N 字节:应答数据
2015-09-05 11:48:38 -04:00
2015-09-14 15:59:52 -04:00
其中数据部分使用 AES-128-CFB 加密IV 为 md5(请求数据 IV)Key 为 md5(请求数据 Key)
2015-09-28 09:10:42 -04:00
## UDP
UDP 数据包为对称设计,即请求和响应的格式一样
* 16 字节:基于时间的 hash(用户 [ID](https://github.com/V2Ray/v2ray-core/blob/master/spec/id.md)),见下文
* 4 字节:余下所有内容的 FNV1a hash
* 1 字节:版本号,目前为 0x1
* 2 字节Token用于区分数据包
* 1 字节:保留,暂为 0x00
* 2 字节:目标端口
* 1 字节:目标类型
* 0x01IPv4
* 0x02域名
* 0x03IPv6
* 目标地址:
* 4 字节IPv4
* 1 字节长度 + 域名
* 16 字节IPv6
* N 字节:请求数据
其中除了 hash 之外的部分经过 AES-128-CFB 加密:
* Keymd5(用户 ID + '22f01806-5ef0-4e88-95ab-b57f1c7a4a40')
* IVmd5(X + X + X + X)X = []byte(UserHash 生成的时间) (8 字节, Big Endian)
2015-09-14 15:59:52 -04:00
## 基于时间的用户 ID Hash
2015-09-14 18:56:17 -04:00
* H = MD5
* K = 用户 ID (16 字节)
2015-09-15 12:25:51 -04:00
* M = UTC 时间,精确到秒,取值为当前时间的前后 30 秒随机值(8 字节, Big Endian)
2015-09-14 18:56:17 -04:00
* Hash = HMAC(H, K, M)