Skip to main content

Command Palette

Search for a command to run...

golang读取ssl的ClientHello

Published
1 min read

问题:作为一个反向代理,如何从ssl中读取到host?

经过半天的看golang的源码……其实代码只有几行,但是特么缺看源码的时间,整理思路 到 尝试。。缺花了很长时间。。

终于把问题解决了,然后写篇博客吧……反而写博客的心里更放松…

需求是这样的:

大家知道nginx的https,配置时可以给每一个server配置ssl。

所以有一个有一个类似的需求:

需要根据不同的域名,加载不同的ssl证书。

但是一般我们不会像nginx,从tcp层读取并解析ssl协议中的 client hello请求。

所以,我就想,既然golang的源码(tls包)已有了,为啥不能直接拿过来用。

so,源码如下:

ln, err := net.Listen("tcp", ":443") // 监听tcp if err != nil { return } for { conn, err := ln.Accept() if err != nil { continue } tlsconn = tls.Server(conn, &tls.Config{}) // 初始化一个tls *tls.Conn tlsconn.Handshake() // 读取tls的握手(Client Hello) state := tlsconn.ConnectionState() // 完成 ConnectionState returns basic TLS details about the connection. this.log.Info("server name ", state.ServerName) // Client hello中的扩展字段会带上server name,这里会输出host }

完毕。

\================

上面的不是很合理,后来发现tls.Config中有一个 GetCertificate 回调方法。。。完美解决。。。

tlsCfg := &tls.Config{ GetCertificate: func(info tls.ClientHelloInfo) (cert tls.Certificate, err error) {

}, }

2 views

More from this blog

会有越来的多的side projects出现

什么是side project 可以理解为工作之余开发的产品,通常是收费的服务,可作为工作之外额外收入的产品。 在目前经济下行、公司开源节流(裁员)、失业率上升的大环境下,每一个程序员都应该拥有自己的side projects来对冲未来的不可靠风险。 所以side project 不仅仅是多一种「被动收入」,他也是你未来的「筹码」——工作累了,不想干了、有小孩了、买房了、家人生病了等等这些事情发生的时候,你可以「任性」一下。 而不是一些不可靠的风险出现的时候,再来提高自己的「抗风险」能力。 上面...

Jul 28, 20231 min read61

Xbox Cloud Gaming 游戏加速尝试

Xbox Cloud Gaming 游戏加速 之前有个很老的xbox游戏机,因为性能有点差劲了,所以卖了。 偶尔还是想玩玩游戏,但是老婆不让给买xbox的物理机(怀恋单身),所以含泪玩xbox cloud gaming(以下简称 xcg),xpg会员游戏还是很丰富的。 于是买了uu加速器,坦白说uu加速器不算便宜的,但是xcg在晚上高峰期,一样卡得怀疑人生,那种被马赛克糊满脸的感受,上一次这种体验还是看小姐姐的电影。 其实用uu加速器玩是ok的,就是国内的网络情况大家都知道,dddd(懂得都懂)...

Sep 5, 20221 min read258

github codespaces 在ipad上的最佳浏览器

Github Codespaces github codespaces 是github在被微软收购后,提供的一款在线web IDE,基本与vscode一致,只是运行在浏览器上而已。 而且非常土豪的提供了4核8G内存,微软就是壕。 so,通过ipad来使用codespaces就是一件比较顺其自然的事。 可是其实也没那么简单。。 IPad使用codespaces的快捷键问题 其实最大的问题就是快捷键的问题,不管你是用saferi,还是chrome,他们提供的快捷键或多或少会与你的vscode的快捷键...

Oct 8, 20211 min read59

基于binlog检查数据错误

起因 某个表的 status 「莫名其妙」变成 0 了 其实可以判断出是 status 没有被赋值,通常是结构体的 status 默认是 0 才会被插入数据库。 于是问题看起来就很简单了:只要检查相关的更新操作中的 status 字段有没有被赋值即可。 但是 这个表是用户表。 因为历史原因,源码中的更新函数很多 调用更新函数的地方也很多 无法复现该问题,测试人员也不知道做了什么操作状态变成 0 的 所以同事关注这个问题挺久了,也没看到问题原因(当然我也没看到……) 但是恰好我在做导出 bin...

Aug 5, 20212 min read61
M

Moli'blog

64 posts

曾经的少年还在吗?