2015-09-05 15:48:38 +00:00
|
|
|
|
# VMess 设计
|
|
|
|
|
## 摘要
|
|
|
|
|
* 版本:1
|
|
|
|
|
|
|
|
|
|
## 数据请求
|
2015-09-05 19:08:52 +00:00
|
|
|
|
版本部分:
|
2015-09-05 15:48:38 +00:00
|
|
|
|
* 1 字节:版本号,目前为 0x1
|
2015-09-07 21:13:55 +00:00
|
|
|
|
|
2015-09-05 19:08:52 +00:00
|
|
|
|
认证部分:
|
2015-09-05 15:48:38 +00:00
|
|
|
|
* 16 字节:md5(用户 VID + 'ASK')
|
2015-09-07 21:13:55 +00:00
|
|
|
|
|
2015-09-05 19:08:52 +00:00
|
|
|
|
指令部分:
|
2015-09-06 23:01:32 +00:00
|
|
|
|
* 1 字节:随机填充长度 M (M <= 32)
|
2015-09-05 15:48:38 +00:00
|
|
|
|
* M 字节:随机填充内容
|
2015-09-05 19:08:52 +00:00
|
|
|
|
* 1 字节:保留,总是 0x00
|
|
|
|
|
* 16 字节:请求数据 IV
|
2015-09-07 12:49:24 +00:00
|
|
|
|
* 16 字节:请求数据 Key
|
2015-09-05 21:03:56 +00:00
|
|
|
|
* 4 字节:认证信息 V
|
2015-09-05 19:08:52 +00:00
|
|
|
|
* 1 字节:指令
|
|
|
|
|
* 0x00:保留
|
|
|
|
|
* 0x01:TCP 请求
|
|
|
|
|
* 0x02:UDP 请求
|
|
|
|
|
* 2 字节:目标端口
|
|
|
|
|
* 1 字节:目标类型
|
|
|
|
|
* 0x01:IPv4
|
|
|
|
|
* 0x02:域名
|
|
|
|
|
* 0x03:IPv6
|
|
|
|
|
* 目标地址:
|
|
|
|
|
* 4 字节:IPv4
|
2015-09-06 23:01:32 +00:00
|
|
|
|
* 1 字节长度 + 域名
|
2015-09-05 19:08:52 +00:00
|
|
|
|
* 16 字节:IPv6
|
2015-09-07 12:49:24 +00:00
|
|
|
|
* 1 字节:随机填充长度 M2 (M2 <= 32)
|
|
|
|
|
* M2 字节:随机填充内容
|
2015-09-07 21:13:55 +00:00
|
|
|
|
|
2015-09-05 19:08:52 +00:00
|
|
|
|
数据部分
|
2015-09-07 21:13:55 +00:00
|
|
|
|
* N 字节:请求数据
|
2015-09-05 15:48:38 +00:00
|
|
|
|
|
2015-09-07 12:49:24 +00:00
|
|
|
|
其中指令部分经过 AES-128 加密,Key 为用户 VID;数据部分使用 AES-128-CBC 加密
|
2015-09-05 15:48:38 +00:00
|
|
|
|
|
|
|
|
|
## 数据应答
|
2015-09-05 19:08:52 +00:00
|
|
|
|
认证部分:
|
2015-09-05 21:03:56 +00:00
|
|
|
|
* 4 字节:认证信息 V
|
2015-09-07 21:13:55 +00:00
|
|
|
|
|
2015-09-05 19:08:52 +00:00
|
|
|
|
数据部分
|
|
|
|
|
* N 字节:应答数据
|
2015-09-05 15:48:38 +00:00
|
|
|
|
|
2015-09-07 12:49:24 +00:00
|
|
|
|
其中数据部分使用 AES-128-CBC 加密,IV 为 md5(请求数据 IV),Key 为 md5(请求数据 Key)
|