1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-17 23:06:30 -05:00
v2fly/spec/vmess.md
2015-09-16 12:26:50 +02:00

55 lines
1.4 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# VMess 设计
## 摘要
* 版本1
## 数据请求
认证部分:
* 16 字节:基于时间的 hash(用户 ID),见下文
指令部分:
* 1 字节:随机填充长度 M (0 < M <= 32)
* M 字节随机填充内容
* 1 字节版本号目前为 0x1
* 16 字节请求数据 IV
* 16 字节请求数据 Key
* 4 字节认证信息 V
* 1 字节指令
* 0x00保留
* 0x01TCP 请求
* 0x02UDP 请求
* 2 字节目标端口
* 1 字节目标类型
* 0x01IPv4
* 0x02域名
* 0x03IPv6
* 目标地址
* 4 字节IPv4
* 1 字节长度 + 域名
* 16 字节IPv6
* 1 字节随机填充长度 M2 (0 < M2 <= 32)
* M2 字节随机填充内容
数据部分
* N 字节请求数据
其中指令部分经过 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 在请求数据中
## 数据应答
认证部分
* 4 字节认证信息 V
数据部分
* N 字节应答数据
其中数据部分使用 AES-128-CFB 加密IV md5(请求数据 IV)Key md5(请求数据 Key)
## 基于时间的用户 ID Hash
* H = MD5
* K = 用户 ID (16 字节)
* M = UTC 时间精确到秒取值为当前时间的前后 30 秒随机值(8 字节, Big Endian)
* Hash = HMAC(H, K, M)