返回顶部
首页 > 资讯 > 后端开发 > GO >尝试向服务器进行身份验证时,连接被对等方重置
  • 123
分享到

尝试向服务器进行身份验证时,连接被对等方重置

2024-04-04 23:04:46 123人浏览 独家记忆
摘要

大家好,我们又见面了啊~本文《尝试向服务器进行身份验证时,连接被对等方重置》的内容中将会涉及到等等。如果你正在学习golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们

大家好,我们又见面了啊~本文《尝试向服务器进行身份验证时,连接被对等方重置》的内容中将会涉及到等等。如果你正在学习golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~

问题内容

我正在尝试通过 go 客户端验证自己的身份。这是我到目前为止所做的事情

func main() {
    servaddr := "192.168.7.13:443"
    tcpaddr, err := net.resolvetcpaddr("tcp", servaddr)
    if err != nil {
        fmt.println("resolvetcpaddr failed:", err.error())
        os.exit(1)
    }

    conn, err := net.dialtcp("tcp", nil, tcpaddr)
    if err != nil {
        fmt.println("dial failed:", err.error())
        os.exit(1)
    }

    _, err = conn.write([]byte(postreq))
    if err != nil {
        fmt.println("write to server failed:", err.error())
        os.exit(1)
    }

    fmt.println(postreq)

    reply := make([]byte, 1024)
    _, err = conn.read(reply)
    if err != nil {
        fmt.println("write to server failed:", err.error())
        os.exit(1)
    }

    fmt.println("reply from server=", string(reply))

    conn.close()
}

这是我正在写入连接的消息:

post /managementserver/servercommandservice.svc Http/1.1 主机: 192.xxx.xx.xx 内容类型:text/xml; charset=utf-8 授权:基本 {用户名:base64 中的密码} 内容长度:405 soapaction:“http://videoos.net/2/xprotectCSServercommand/iservercommandservice/login” 连接:保持活动状态 190fc316-6412-41c4-8a9c-d468cc7bee9d

在此之后,我希望获得身份验证令牌,但我得到的是

> Write to server failed: read tcp server-ip:port->server-ip:443:
> read: connection reset by peer

我做错了什么? 仅供参考,我在 python 中使用相同的消息,并且通过套接字我能够获取令牌。有人可以帮我在 go 语言中做同样的事情吗?谢谢


解决方案


从事实来看,您的服务器使用端口 443,我假设服务器需要 tls 连接。要获得这样的连接,您可以使用tls.Dial

conn, err := tls.dial("tcp", servaddr, nil) // servaddr not tcpaddr

此连接将处理 tls 加密所需的基础步骤(例如 tls 握手),并允许您 write 您想要发送的字节,而不必自己进行加密。

正如您提到的证书验证错误,使用

conn, err := tls.dial("tcp", servaddr, &tls.config{insecureskipverify: true})

将禁用此验证。 请注意,这会删除 tls 提供的大部分安全性。

需要注意的是,我建议您使用 net/http 发送简单的 http 请求。要在此处禁用证书验证,您可以使用

http.DefaultTransport.(*http.Transport).TLSClientConfig = &tls.Config{InsecureSkipVerify: true}

但是,请注意,这会删除 tls 提供的大部分安全性。您可以查看 this answer,了解有关使用 net.http 发送请求时禁用此功能的更多详细信息。

本篇关于《尝试向服务器进行身份验证时,连接被对等方重置》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注编程网公众号!

您可能感兴趣的文档:

--结束END--

本文标题: 尝试向服务器进行身份验证时,连接被对等方重置

本文链接: https://lsjlt.com/news/596000.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作