2015-09-05 11:48:38 -04:00
|
|
|
|
# VMess 设计
|
|
|
|
|
## 摘要
|
|
|
|
|
* 版本:1
|
|
|
|
|
|
|
|
|
|
## 数据请求
|
2015-09-05 15:08:52 -04:00
|
|
|
|
认证部分:
|
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-05 15:08:52 -04:00
|
|
|
|
指令部分:
|
2015-09-14 15:59:52 -04:00
|
|
|
|
* 1 字节:版本号,目前为 0x1
|
2015-09-05 15:08:52 -04:00
|
|
|
|
* 16 字节:请求数据 IV
|
2015-09-07 08:49:24 -04:00
|
|
|
|
* 16 字节:请求数据 Key
|
2015-09-05 17:03:56 -04:00
|
|
|
|
* 4 字节:认证信息 V
|
2015-09-05 15:08:52 -04:00
|
|
|
|
* 1 字节:指令
|
|
|
|
|
* 0x00:保留
|
|
|
|
|
* 0x01:TCP 请求
|
|
|
|
|
* 0x02:UDP 请求
|
|
|
|
|
* 2 字节:目标端口
|
|
|
|
|
* 1 字节:目标类型
|
|
|
|
|
* 0x01:IPv4
|
|
|
|
|
* 0x02:域名
|
|
|
|
|
* 0x03:IPv6
|
|
|
|
|
* 目标地址:
|
|
|
|
|
* 4 字节:IPv4
|
2015-09-06 19:01:32 -04:00
|
|
|
|
* 1 字节长度 + 域名
|
2015-09-05 15:08:52 -04:00
|
|
|
|
* 16 字节:IPv6
|
2015-09-22 18:29:10 -04:00
|
|
|
|
* 4 字节:指令部分前面所有内容的 FNV1a hash
|
2015-09-07 17:13:55 -04:00
|
|
|
|
|
2015-09-05 15:08:52 -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 加密:
|
|
|
|
|
* Key:md5(用户 ID + 'c48619fe-8f02-49e0-b9e9-edf763e17e21')
|
|
|
|
|
* IV:md5(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-05 15:08:52 -04:00
|
|
|
|
数据部分
|
2015-09-17 18:14:17 -04:00
|
|
|
|
* 4 字节:认证信息 V
|
2015-09-05 15:08:52 -04:00
|
|
|
|
* 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)
|
|
|
|
|
|
|
|
|
|
## 基于时间的用户 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)
|