proxy --->Server In this environment, the client is behind the http proxy, and the client needs to utilize the proxy http tunnel in"/> proxy --->Server In this environment, the client is behind the http proxy, and the client needs to utilize the proxy http tunnel in">
Home >Backend Development >Golang >How to send Client Hello through http proxy tunnel
I have a client that will establish a tls connection to a backend service.
There are two situations I encountered.
In this environment, the client connects directly to the server, as shown in the following code.
var d tls.dialer //... d.config = &tls.config{ //... } //... c1 := d.dial("tcp", addr)
In this environment, the client is behind an http proxy and the client needs to utilize the proxy http tunnel to forward traffic between the client and the server.
I use golang.org/x/net/proxy
on the client side to connect to the proxy, because the proxy is an http proxy, the client should use net.dialer to connect to the proxy through tcp.
dailer, err := proxy.FromURL(proxy, &net.Dialer{ Timeout: TCP_CONNECT_TIMEOUT, KeepAlive: TCP_KEEPALIVE_TIMEOUT, }) c2 := dailer.Dial("tcp", addr)
Case 1, the client starts the tls connection. In the network traffic packet, the client triggers the tcp connection. After 3 handshakes, the client sends client hello
to the server.
In case 2, the client first uses tcp to connect to the http proxy (for example 10.0.0.1:8080), next, sends connect
to the proxy, and then the proxy returns connectionestablished
, But the client does not send client hello
to the server.
For case2, I don't know how and where to implement sending client hello
on the client side?
Thanks in advance.
After searching go doc, I found the solution. I hope it will be useful to people who encounter similar problems later.
In tls
, there is a function client that can be built from an existing network. Conn, then use Handshake
tlsConn := tls.Client(conn, &tls.Config{ Certificates: []tls.Certificate{*cert}, InsecureSkipVerify: true, ServerName: sni, ClientAuth: tls.RequestClientCert, }) err = tlsConn.Handshake()
The above is the detailed content of How to send Client Hello through http proxy tunnel. For more information, please follow other related articles on the PHP Chinese website!