forked from mediahome/javscrape
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathproxy.go
85 lines (76 loc) · 1.69 KB
/
proxy.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package scrape
import (
"context"
"crypto/tls"
"net"
"net/http"
"net/url"
"time"
"golang.org/x/net/proxy"
)
//var log = trait.NewZapSugar()
var cli *http.Client
// ProxyArgs ...
type ProxyArgs func(cli *http.Client)
// TimeOut ...
func TimeOut(sec int) ProxyArgs {
return func(cli *http.Client) {
cli.Timeout = time.Duration(sec) * time.Second
}
}
// RegisterProxy ...
func RegisterProxy(addr string, args ...ProxyArgs) (e error) {
u, e := url.Parse(addr)
if e != nil {
return e
}
var transport *http.Transport
switch u.Scheme {
case "http", "https":
transport = getHTTPTransport(u)
case "socks5":
transport = getSOCKS5Transport(u.Host)
default:
transport = &http.Transport{
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
}
}
cli = &http.Client{
Transport: transport,
CheckRedirect: nil,
Jar: nil,
Timeout: 60 * time.Second,
}
for _, fn := range args {
fn(cli)
}
return nil
}
func getHTTPTransport(u *url.URL) *http.Transport {
return &http.Transport{
Proxy: http.ProxyURL(u),
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
}
}
func proxySOCKS5(addr string) (proxy.Dialer, error) {
return proxy.SOCKS5("tcp", addr,
nil, //&proxy.Auth{User: "", Password: ""},
&net.Dialer{
Timeout: 30 * time.Second,
KeepAlive: 30 * time.Second,
},
)
}
func getSOCKS5Transport(addr string) *http.Transport {
queryProxy, err := proxySOCKS5(addr)
if err != nil {
return &http.Transport{
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
}
}
return &http.Transport{
DialContext: func(ctx context.Context, network, addr string) (conn net.Conn, e error) {
return queryProxy.Dial(network, addr)
},
}
}