111 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Markdown
		
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Markdown
		
	
	
# VMess
 | 
						||
 | 
						||
[VMess](../../development/protocols/vmess.md) 是一个加密传输协议,通常作为 Xray 客户端和服务器之间的桥梁。
 | 
						||
 | 
						||
::: danger
 | 
						||
VMess 依赖于系统时间,请确保使用 Xray 的系统 UTC 时间误差在 120 秒之内,时区无关。在 Linux 系统中可以安装`ntp`服务来自动同步系统时间。
 | 
						||
:::
 | 
						||
 | 
						||
## OutboundConfigurationObject
 | 
						||
 | 
						||
```json
 | 
						||
{
 | 
						||
  "vnext": [
 | 
						||
    {
 | 
						||
      "address": "127.0.0.1",
 | 
						||
      "port": 37192,
 | 
						||
      "users": [
 | 
						||
        {
 | 
						||
          "id": "5783a3e7-e373-51cd-8642-c83782b807c5",
 | 
						||
          "security": "auto",
 | 
						||
          "level": 0
 | 
						||
        }
 | 
						||
      ]
 | 
						||
    }
 | 
						||
  ]
 | 
						||
}
 | 
						||
```
 | 
						||
 | 
						||
> `vnext`:\[ [ServerObject](#serverobject) \]
 | 
						||
 | 
						||
一个数组,包含一组的服务端配置.
 | 
						||
 | 
						||
其中每一项是一个服务端配置[ServerObject](#serverobject)。
 | 
						||
 | 
						||
### ServerObject
 | 
						||
 | 
						||
```json
 | 
						||
{
 | 
						||
  "address": "127.0.0.1",
 | 
						||
  "port": 37192,
 | 
						||
  "users": []
 | 
						||
}
 | 
						||
```
 | 
						||
 | 
						||
> `address`: address
 | 
						||
 | 
						||
服务端地址,支持 IP 地址或者域名。
 | 
						||
 | 
						||
> `port`: number
 | 
						||
 | 
						||
服务端监听的端口号, 必填。
 | 
						||
 | 
						||
> `users`: \[ [UserObject](#userobject) \]
 | 
						||
 | 
						||
一个数组,代表一组服务端认可的用户.
 | 
						||
 | 
						||
其中每一项是一个用户[UserObject](#userobject)。
 | 
						||
 | 
						||
#### UserObject
 | 
						||
 | 
						||
```json
 | 
						||
{
 | 
						||
  "id": "5783a3e7-e373-51cd-8642-c83782b807c5",
 | 
						||
  "security": "auto",
 | 
						||
  "level": 0
 | 
						||
}
 | 
						||
```
 | 
						||
 | 
						||
> `id`:string
 | 
						||
 | 
						||
Vmess 的用户 ID,可以是任意小于 30 字节的字符串, 也可以是一个合法的 UUID.
 | 
						||
 | 
						||
自定义字符串和其映射的 UUID 是等价的, 这意味着你将可以这样在配置文件中写 id 来标识同一用户,即
 | 
						||
 | 
						||
- 写 `"id": "我爱🍉老师1314"`,
 | 
						||
- 或写 `"id": "5783a3e7-e373-51cd-8642-c83782b807c5"` (此 UUID 是 `我爱🍉老师1314` 的 UUID 映射)
 | 
						||
 | 
						||
其映射标准在 [VLESS UUID 映射标准:将自定义字符串映射为一个 UUIDv5](https://github.com/XTLS/Xray-core/issues/158)
 | 
						||
 | 
						||
你可以使用命令 `xray uuid -i "自定义字符串"` 生成自定义字符串所映射的的 UUID, 也可以使用命令 `xray uuid` 生成随机的 UUID。
 | 
						||
 | 
						||
> `level`: number
 | 
						||
 | 
						||
用户等级,连接会使用这个用户等级对应的 [本地策略](../policy.md#levelpolicyobject)。
 | 
						||
 | 
						||
level 的值, 对应 [policy](../policy.md#policyobject) 中 `level` 的值。 如不指定, 默认为 0。
 | 
						||
 | 
						||
> `security`: "aes-128-gcm" | "chacha20-poly1305" | "auto" | "none" | "zero"
 | 
						||
 | 
						||
加密方式,客户端将使用配置的加密方式发送数据,服务器端自动识别,无需配置。
 | 
						||
 | 
						||
- `"aes-128-gcm"`:推荐在 PC 上使用
 | 
						||
- `"chacha20-poly1305"`:推荐在手机端使用
 | 
						||
- `"auto"`:默认值,自动选择(运行框架为 AMD64、ARM64 或 s390x 时为 aes-128-gcm 加密方式,其他情况则为 Chacha20-Poly1305 加密方式)
 | 
						||
- `"none"`:不加密
 | 
						||
 | 
						||
* `"zero"`:不加密,也不进行消息认证 (v1.4.0+)
 | 
						||
 | 
						||
::: tip
 | 
						||
推荐使用`"auto"`加密方式,这样可以永久保证安全性和兼容性。
 | 
						||
 | 
						||
`"none"` 伪加密方式会计算并验证数据包的校验数据,由于认证算法没有硬件支持,在部分平台可能速度比有硬件加速的 `"aes-128-gcm"` 还慢。
 | 
						||
 | 
						||
`"zero"` 伪加密方式不会加密消息也不会计算数据的校验数据,因此理论上速度会高于其他任何加密方式。实际速度可能受到其他因素影响。
 | 
						||
 | 
						||
不推荐在未开启 TLS 加密并强制校验证书的情况下使用 `"none"` `"zero"` 伪加密方式。
 | 
						||
如果使用 CDN 或其他会解密 TLS 的中转平台或网络环境建立连接,不建议使用 `"none"` `"zero"` 伪加密方式。
 | 
						||
 | 
						||
无论使用哪种加密方式, VMess 的包头都会受到加密和认证的保护。
 | 
						||
:::
 |