登录
首页 >  Golang >  Go问答

连接和维护与socks5代理服务器的连接的身份验证

来源:stackoverflow

时间:2024-03-24 21:18:40 480浏览 收藏

在 Go 中连接到 SOCKS5 代理服务器时,如果通过代理提供商设置了 IP 授权,则连接很容易建立。然而,如果需要使用凭据进行身份验证,则 net.dial 函数无法传递任何凭据。 Go 提供了一个代理库,允许使用以下代理通过代理进行身份验证转发请求。但是,它返回一个拨号器,要求通过经过身份验证的代理连接目标地址,而不是代理服务器本身。因此,目标是返回与经过凭据身份验证的代理服务器的 net.conn 连接。

问题内容

我正在尝试使用凭据进行拨号并在 go 中保持与ocks5代理服务器的连接。

如果我通过代理提供商设置了 ip 授权,则效果很好,但是无法使用 go 中的 net.dial 函数传递任何身份验证凭据:

package main

import (
    "io"
    "net"
)

func main() {

    dst, err := net.dial("tcp", "11.22.33.44:1111")
    if err != nil {
        panic("dial error:" + err.error())
    }

    dst.close()
}

go 有一个有用的代理库,并允许使用以下代理通过代理进行身份验证转发请求:

package main

import (
    "io"
    "net"
)

func main() {

    var proxyauth *proxy.auth
    if conf.username != "" {
        proxyauth = new(proxy.auth)
        proxyauth.user = conf.username
        proxyauth.password = conf.password
    }

    proxyconn, _ := proxy.socks5("tcp", "11.11.11.11:1111", proxyauth, nil) //returns a dialer with proxy that can be invoked to connect to another address

    dst := proxyconn.dial("tcp", "22.33.44.55:6666") //connects to an address via proxy

    dst.close()
}

但是它返回一个拨号器,然后要求通过此经过身份验证的代理而不是代理服务器本身连接目标/最终地址:

我的目标是返回与经过凭据身份验证的代理服务器的 net.conn 连接 - 如下所示:

package main

import (
    "io"
    "net"
)

func main() {

    //net.Dial does not have a way to pass Auth creds
    dst := net.Dial("tcp", "22.33.44.55:6666", proxyAuth)

    dst.Close()
}

正确答案


net.dial() 方法不关心代理身份验证。但是,如果您想要代理身份验证,您可以在调用之前将其设置在请求的标头中。请参考这个link

dst := net.Dial("tcp", "22.33.44.55:6666")

到这里,我们也就讲完了《连接和维护与socks5代理服务器的连接的身份验证》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>