首页 > 解决方案 > 使用 golang 1.10.2 连接到带有 IKEv2 证书的 socks5 代理

问题描述

我将 Go 1.10.2 用于我的客户端应用程序。

我正在尝试连接到需要用户名、密码和 IKEv2 证书文件的 socks5 代理。

这是我到目前为止所得到的:

 func socks5(proxyAdress string, url string, user string, password string) {
        auth := proxy.Auth{User: user, Password: password}
        if proxy, err := proxy.SOCKS5("tcp", proxyAdress, &auth, proxy.Direct);  err != nil {
            log.Fatalf("error: %v", proxy)
        } else {
            tr := &http.Transport{Dial: proxy.Dial}

            // Create client
            myClient := &http.Client{
                Transport: tr,
            }

            if resp, err2 := myClient.Get(url); err2 != nil {
                log.Fatalf("error: %v", err2)
            } else {
                if bodyBytes, err3 := ioutil.ReadAll(resp.Body); err3 != nil {
                    log.Fatalf("error: %v", err3)
                } else {
                    str := string(bodyBytes)
                    log.Printf(str)
                }

            }
        }
    }

当我使用适当的参数执行此功能时

我从服务器收到一个错误,提示我无权访问我请求的网页。那是因为我没有指定 IKEv2 密钥文件。

所以..首先..我该怎么做?

并且第二个...Dial已弃用..我应该使用DialContext但不知道如何使用

谢谢 !:)

更新

我使用的操作系统是 MacOS High Sierra 10.13.4

问题是,例如当我执行

socks5("il7.nordvpn.com:1080", "http://ifconfig.me/ip","MY_USER","MY_PASS")

我得到的错误是

2018/05/15 23:34:49 error: Get http://ifconfig.me/ip: socks connect tcp ifconfig.me:80->ifconfig.me:80: EOF

我不知道在哪里提供 IKEv2 证书

标签: goproxysocks

解决方案


我认为您需要先在计算机上设置 IPSec。

设置 IPSec 的步骤

  1. 初始配置(第一次仅一次)
  2. 启动 VPN 连接

关注这里


推荐阅读