-
Notifications
You must be signed in to change notification settings - Fork 3.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ECH: client support TLS Encrypted Client Hello #3813
base: main
Are you sure you want to change the base?
Conversation
有一个最大的问题是utls是go121的似乎 现在还不支持 遥遥落后了 |
Win7 编译也需要 go121,所以等 2025 再加这个吧,至少得 utls 支持,而且感觉无法通过本地 dns 拿到 echConfig 的话有点鸡肋 最大的问题还是 GFW 又会严控 DNS 了 |
这点我考虑过了 稍后可以加build tag绕过低版本go 就像隔壁一样 至于utls 等它支持了 核心改两行代码就能跟上了 目前这个实验性功能应该没有什么坏处
在配置里加一个可选的doh服务器用于获取解析? 或者尝试写死 观察一段时间 不知道CF这个ECH config是不是轮动的 如果不是的话写死也能接受 |
先写一下通过 dns 获取 echConfig,然后等 utls 支持了再合这个 pr 吧, |
有一个小问题是内置DNS服务器只能处理A和AAAA 这个要再加就得外置 |
好了 现在支持 |
好了已经通过测试 websocket可以设置doh sever然后通过ECH连接到cloudflare |
看了一下非常棒!建议及早合并 |
既然这个在 v2fly 和这里都开了并且不是 draft、没有进一步行动,那么:
for _, answer := range msg.Answer {
if https, ok := answer.(*dns.HTTPS); ok && https.Hdr.Name == dns.Fqdn(domain) {
for _, v := range https.Value {
if echConfig, ok := v.(*dns.SVCBECHConfig); ok {
return echConfig.ECH, answer.Header().Ttl, nil
}
}
}
}
建议重写或转 draft |
@dyhkwong 感谢指正 有的问题我也知道不过没打算合我也没动了 等会改一下 不过有必要ctx吗 log里用Background的原因是GetTLSConfig这个函数就没有ctx 至于内部管理 我想这么简单大概没有必要? |
|
仅客户端
才发现go1.23官方已经支持了 之前写过的那堆复杂替换也不需要了 就正常写入就行了 ws和splithttp预计都能使用cloudflare的ECH
目前是写死的 稍后可以考虑从DNS中获取 已经测试可以和singbox与cloudflare建立ECH连接
写法