大家好,我们又见面了啊~本文《尝试向服务器进行身份验证时,连接被对等方重置》的内容中将会涉及到等等。如果你正在学习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的相关知识,请关注编程网公众号!