mirror of
https://github.com/e1732a364fed/v2ray_simple.git
synced 2025-12-24 13:27:56 +08:00
41 lines
1.6 KiB
Go
41 lines
1.6 KiB
Go
/*
|
||
Package v2ray_simple provides a simple way to set up a proxy.
|
||
|
||
# Structure 本项目结构
|
||
|
||
utils -> netLayer-> tlsLayer -> httpLayer -> advLayer -> proxy -> v2ray_simple -> machine -> cmd/verysimple
|
||
|
||
根项目 v2ray_simple 仅研究实际转发过程. 关于 代理的详细定义 请参考 proxy 子包的文档。
|
||
|
||
本项目是一个代理项目,最重要的事情就是 【如何转发流量】,所以主项目主要研究这个转发过程。
|
||
|
||
目前主要内容有:
|
||
|
||
ListenSer函数用于主要 代理的转发。内置了 lazy的转发逻辑。
|
||
|
||
使用方式可以阅读 tcp_test.go 和 udp_test.go
|
||
|
||
# Chain
|
||
|
||
具体 转发过程 的 调用链 是 ListenSer -> handleNewIncomeConnection ->
|
||
handshakeInserver_and_passToOutClient -> { handshakeInserver , passToOutClient ->
|
||
[ ( checkfallback) -> dialClient_andRelay -> 「 dialClient ( -> dialInnerProxy ),
|
||
netLayer.Relay / netLayer.RelayUDP 」 ] }
|
||
|
||
用 netLayer操纵路由,用tlsLayer嗅探tls,用httpLayer操纵回落,可选经过http头、高级层、innerMux, 都搞好后,进行 proxy 握手,然后就开始转发。
|
||
|
||
# TLS Lazy Encryption - Lazy
|
||
|
||
TLS Lazy Encryption 技术 可简称为 tls lazy encrypt, tls lazy 或者 lazy.
|
||
|
||
lazy 是一种 独特的 转发方式,所以也是在 本包中处理,而不是在proxy包中处理。
|
||
proxy包只负责定义,不负责实际转发。
|
||
|
||
lazy 与 xtls类似,在一定条件下可以利用内层tls加密直接传输数据,不在外面再包一层tls。
|
||
|
||
lazy与xtls的不同是,lazy不魔改tls包,所以是可以在 uTLS 的基础上 进行 lazy的,而且也没有 xtls的233漏洞。
|
||
|
||
目前lazy还在完善阶段。
|
||
*/
|
||
package v2ray_simple
|