You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
1.9 KiB
Go
86 lines
1.9 KiB
Go
package flow
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"net"
|
|
"net/http"
|
|
"time"
|
|
|
|
"github.com/lqqyt2423/go-mitmproxy/connection"
|
|
)
|
|
|
|
var ConnContextKey = new(struct{})
|
|
|
|
type ConnContext struct {
|
|
Client *connection.Client
|
|
Server *connection.Server
|
|
}
|
|
|
|
func (connCtx *ConnContext) InitHttpServer(SslInsecure bool) {
|
|
if connCtx.Server != nil {
|
|
return
|
|
}
|
|
if connCtx.Client.Tls {
|
|
return
|
|
}
|
|
|
|
server := connection.NewServer()
|
|
server.Client = &http.Client{
|
|
Transport: &http.Transport{
|
|
Proxy: http.ProxyFromEnvironment,
|
|
|
|
// todo: change here
|
|
DialContext: (&net.Dialer{
|
|
Timeout: 30 * time.Second,
|
|
KeepAlive: 30 * time.Second,
|
|
}).DialContext,
|
|
ForceAttemptHTTP2: false, // disable http2
|
|
|
|
DisableCompression: true, // To get the original response from the server, set Transport.DisableCompression to true.
|
|
TLSClientConfig: &tls.Config{
|
|
InsecureSkipVerify: SslInsecure,
|
|
KeyLogWriter: GetTlsKeyLogWriter(),
|
|
},
|
|
},
|
|
CheckRedirect: func(req *http.Request, via []*http.Request) error {
|
|
// 禁止自动重定向
|
|
return http.ErrUseLastResponse
|
|
},
|
|
}
|
|
connCtx.Server = server
|
|
}
|
|
|
|
func (connCtx *ConnContext) InitHttpsServer(SslInsecure bool) {
|
|
if connCtx.Server != nil {
|
|
return
|
|
}
|
|
if !connCtx.Client.Tls {
|
|
return
|
|
}
|
|
|
|
server := connection.NewServer()
|
|
server.Client = &http.Client{
|
|
Transport: &http.Transport{
|
|
Proxy: http.ProxyFromEnvironment,
|
|
|
|
// todo: change here
|
|
DialContext: (&net.Dialer{
|
|
Timeout: 30 * time.Second,
|
|
KeepAlive: 30 * time.Second,
|
|
}).DialContext,
|
|
ForceAttemptHTTP2: false, // disable http2
|
|
|
|
DisableCompression: true, // To get the original response from the server, set Transport.DisableCompression to true.
|
|
TLSClientConfig: &tls.Config{
|
|
InsecureSkipVerify: SslInsecure,
|
|
KeyLogWriter: GetTlsKeyLogWriter(),
|
|
},
|
|
},
|
|
CheckRedirect: func(req *http.Request, via []*http.Request) error {
|
|
// 禁止自动重定向
|
|
return http.ErrUseLastResponse
|
|
},
|
|
}
|
|
connCtx.Server = server
|
|
}
|