119 lines
4.8 KiB
Markdown
Raw Normal View History

2021-05-26 19:05:53 +08:00
# VMess
[VMess](../../development/protocols/vmess.md) is an encrypted transport protocol commonly used as a bridge between Xray clients and servers.
2021-05-26 19:05:53 +08:00
::: danger
VMess relies on system time. Please ensure that the UTC time of your system, when using Xray, has an error within 90 seconds, regardless of the time zone. On Linux systems, you can install the `ntp` service to automatically synchronize the system time.
2021-05-26 19:05:53 +08:00
:::
## OutboundConfigurationObject
```json
{
"vnext": [
{
"address": "127.0.0.1",
"port": 37192,
"users": [
{
"id": "5783a3e7-e373-51cd-8642-c83782b807c5",
"alterId": 0,
"security": "auto",
"level": 0
}
]
}
]
}
```
> `vnext`\[ [ServerObject](#serverobject) \]
An array containing a set of server configurations.
2021-05-26 19:05:53 +08:00
Each item in the array is a server configuration [ServerObject](#serverobject).
2021-05-26 19:05:53 +08:00
### ServerObject
```json
{
"address": "127.0.0.1",
"port": 37192,
"users": []
}
```
> `address`: address
The server address, which can be an IP address or domain name.
2021-05-26 19:05:53 +08:00
> `port`: number
The port number that the server is listening on. Required.
2021-05-26 19:05:53 +08:00
> `users`: \[ [UserObject](#userobject) \]
An array representing a group of users authorized by the server.
2021-05-26 19:05:53 +08:00
Each item is a user configuration [UserObject](#userobject).
2021-05-26 19:05:53 +08:00
#### UserObject
```json
{
"id": "5783a3e7-e373-51cd-8642-c83782b807c5",
"alterId": 0,
"security": "auto",
"level": 0
}
```
> `id`: string
2021-05-26 19:05:53 +08:00
The user ID for VMess, which can be any string less than 30 bytes or a valid UUID.
2021-05-26 19:05:53 +08:00
Custom strings and their corresponding UUIDs are equivalent. This means that you can use either a custom string or its corresponding UUID to identify the same user in the configuration file. For example:
2021-05-26 19:05:53 +08:00
- Write `"id": "我爱🍉老师1314"`,
- Or write `"id": "5783a3e7-e373-51cd-8642-c83782b807c5"` (this UUID is the mapping of the custom string "我爱 🍉 老师 1314")
2021-05-26 19:05:53 +08:00
The mapping standard is described in the [VLESS UUID Mapping Standard: Mapping a Custom String to a UUIDv5](https://github.com/XTLS/Xray-core/issues/158).
2021-05-26 19:05:53 +08:00
You can use the command `xray uuid -i "custom string"` to generate the UUID corresponding to a custom string, or use the command `xray uuid` to generate a random UUID.
2021-05-26 19:05:53 +08:00
> `alterId`number
To further prevent detection, a user can generate additional IDs in addition to the main ID. Here, you only need to specify the number of additional IDs. The recommended value is 0, which means VMessAEAD is enabled. The maximum value is 65535. This value cannot exceed the value specified on the server side.
2021-05-26 19:05:53 +08:00
If not specified, the default value is 0.
2021-05-26 19:05:53 +08:00
::: tip Setting the client's AlterID to 0 enables VMessAEAD. The server automatically adapts and can simultaneously be compatible with clients that have enabled or disabled VMessAEAD. The client can forcefully disable VMessAEAD by setting the environment variable `Xray_VMESS_AEAD_DISABLED=true`. :::
2021-05-26 19:05:53 +08:00
> `level`: number
The user level. Connections will use the corresponding [local policy](../policy.md#levelpolicyobject) associated with this user level.
2021-05-26 19:05:53 +08:00
The `level` value corresponds to the `level` value in the [policy](../policy.md#policyobject). If not specified, the default value is 0.
2021-05-26 19:05:53 +08:00
> `security`: "aes-128-gcm" | "chacha20-poly1305" | "auto" | "none" | "zero"
The encryption method. The client will use the configured encryption method to send data, and the server will automatically recognize it without the need for configuration.
2021-05-26 19:05:53 +08:00
- `"aes-128-gcm"`: Recommended for use on PCs.
- `"chacha20-poly1305"`: Recommended for use on mobile devices.
- `"auto"`: Default value. Automatically selects the encryption method (uses aes-128-gcm when running on AMD64, ARM64, or s390x architecture, and Chacha20-Poly1305 in other cases).
- `"none"`: No encryption.
- `"zero"`: No encryption and no message authentication (v1.4.0+).
2021-05-26 19:05:53 +08:00
::: tip
It is recommended to use the `"auto"` encryption method as it ensures long-term security and compatibility.
2021-05-26 19:05:53 +08:00
The `"none"` pseudo-encryption method calculates and verifies the packet's checksum. However, due to the lack of hardware support for the authentication algorithm, it may be slower than the hardware-accelerated `"aes-128-gcm"` on some platforms.
2021-05-26 19:05:53 +08:00
The `"zero"` pseudo-encryption method neither encrypts the message nor calculates the checksum, theoretically providing higher speed than any other encryption method. The actual speed may be influenced by other factors.
2021-05-26 19:05:53 +08:00
It is not recommended to use the `"none"` or `"zero"` pseudo-encryption methods without enabling TLS encryption and forcibly verifying certificates. If you use a CDN or other intermediate platforms or network environments that decrypt TLS connections, it is not recommended to use the `"none"` or `"zero"` pseudo-encryption methods.
2021-05-26 19:05:53 +08:00
Regardless of the encryption method used, the VMess packet header is protected by encryption and authentication.
2021-05-26 19:05:53 +08:00
:::