2021-05-26 11:05:53 +00:00
# TCP
2023-03-28 02:43:59 +00:00
TCP (Transmission Control Protocol) is currently one of the recommended transport protocols
2021-05-26 11:05:53 +00:00
2023-03-28 02:43:59 +00:00
It can be combined with various protocols in multiple ways.
2021-05-26 11:05:53 +00:00
## TcpObject
2023-03-28 02:43:59 +00:00
`TcpObject` corresponds to the `tcpSettings` item in the Transport Protocol.
2021-05-26 11:05:53 +00:00
```json
{
"acceptProxyProtocol": false,
"header": {
"type": "none"
}
}
```
> `acceptProxyProtocol`: true | false
2023-03-28 02:43:59 +00:00
Only used for inbound, indicating whether to accept the PROXY protocol.
2021-05-26 11:05:53 +00:00
2023-03-28 02:43:59 +00:00
The [PROXY protocol ](https://www.haproxy.org/download/2.2/doc/proxy-protocol.txt ) is used to transmit the real source IP and port of the request. **If you are not familiar with it, please ignore this item.**
2021-05-26 11:05:53 +00:00
2023-03-28 02:43:59 +00:00
Common reverse proxy software (such as HAProxy and Nginx) can be configured to send it, and VLESS fallbacks xver can also send it.
2021-05-26 11:05:53 +00:00
2023-03-28 02:43:59 +00:00
When filled in as `true` , after the underlying TCP connection is established, the requesting party must first send PROXY protocol v1 or v2, otherwise the connection will be closed.
2021-05-26 11:05:53 +00:00
2023-03-28 02:43:59 +00:00
The default value is `false`
2021-05-26 11:05:53 +00:00
> `header`: [NoneHeaderObject](#noneheaderobject) | [HttpHeaderobject](#httpheaderobject)
2023-03-28 02:43:59 +00:00
Packet header obfuscation settings, the default value is `NoneHeaderObject`
2021-05-26 11:05:53 +00:00
::: tip
2023-03-28 02:43:59 +00:00
HTTP obfuscation cannot be proxied by other HTTP servers (such as Nginx), but it can be proxied by VLESS fallbacks path.
2021-05-26 11:05:53 +00:00
:::
### NoneHeaderObject
2023-03-28 02:43:59 +00:00
No header obfuscation
2021-05-26 11:05:53 +00:00
```json
{
"type": "none"
}
```
> `type`: "none"
2023-03-28 02:43:59 +00:00
Disable header obfuscation.
2021-05-26 11:05:53 +00:00
### HttpHeaderObject
2023-03-28 02:43:59 +00:00
HTTP header obfuscation. The configuration must be the same between connecting inbound and outbound.
2021-05-26 11:05:53 +00:00
```json
{
"type": "http",
"request": {},
"response": {}
}
```
> `type`: "http"
2023-03-28 02:43:59 +00:00
Enable HTTP header obfuscation.
2021-05-26 11:05:53 +00:00
> `request`: [HTTPRequestObject](#httprequestobject)
2023-03-28 02:43:59 +00:00
HTTP request template.
2021-05-26 11:05:53 +00:00
> `response`: [HTTPResponseObject](#httpresponseobject)
2023-03-28 02:43:59 +00:00
HTTP response template.
2021-05-26 11:05:53 +00:00
#### HTTPRequestObject
```json
{
"version": "1.1",
"method": "GET",
"path": ["/"],
"headers": {
"Host": ["www.baidu.com", "www.bing.com"],
"User-Agent": [
"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
"Mozilla/5.0 (iPhone; CPU iPhone OS 10_0_2 like Mac OS X) AppleWebKit/601.1 (KHTML, like Gecko) CriOS/53.0.2785.109 Mobile/14A456 Safari/601.1.46"
],
"Accept-Encoding": ["gzip, deflate"],
"Connection": ["keep-alive"],
"Pragma": "no-cache"
}
}
```
> `version`: string
2023-03-28 02:43:59 +00:00
HTTP version, the default value is `"1.1"`
2021-05-26 11:05:53 +00:00
> `method`: string
2023-03-28 02:43:59 +00:00
The HTTP method, the default value is `"GET"`
2021-05-26 11:05:53 +00:00
> `path`: \[ string \]
2023-03-28 02:43:59 +00:00
paths, an array of strings. The default value is `["/"]` . When there are multiple values, a value is chosen randomly for each request.
2021-05-26 11:05:53 +00:00
> `headers`: map{ string, \[ string \]}
2023-03-28 02:43:59 +00:00
HTTP header, a key-value pair, each key represents the name of an HTTP header, and the corresponding value is an array.
2021-05-26 11:05:53 +00:00
2023-03-28 02:43:59 +00:00
Each request will include all the keys and randomly select a corresponding value. Please refer to the **default values** shown in the example above.
2021-05-26 11:05:53 +00:00
#### HTTPResponseObject
```json
{
"version": "1.1",
"status": "200",
"reason": "OK",
"headers": {
"Content-Type": ["application/octet-stream", "video/mpeg"],
"Transfer-Encoding": ["chunked"],
"Connection": ["keep-alive"],
"Pragma": "no-cache"
}
}
```
> `version`: string
2023-03-28 02:43:59 +00:00
HTTP version, default is `"1.1"`
2021-05-26 11:05:53 +00:00
> `status`: string
2023-03-28 02:43:59 +00:00
HTTP status, default is `"200"`
2021-05-26 11:05:53 +00:00
> `reason`: string
2023-03-28 02:43:59 +00:00
HTTP status description, default value is `"OK"`
2021-05-26 11:05:53 +00:00
> `headers`: map {string, \[ string \]}
2023-03-28 02:43:59 +00:00
HTTP header, a key-value pair, each key represents the name of an HTTP header, and the corresponding value is an array.
2021-05-26 11:05:53 +00:00
2023-03-28 02:43:59 +00:00
Each request will include all the keys and randomly select a corresponding value. Please refer to the **default values** shown in the example above.