登录
首页 >  Golang >  Go问答

TLS错误:未执行HTTP请求的重新协商

来源:stackoverflow

时间:2024-03-23 10:12:30 133浏览 收藏

在执行 HTTP 请求时遇到“tls:无重新协商”错误,作者在遵循官方指南后,发现启用 TLS 重新协商(`tls.Config.Renegotiation`)解决了问题。虽然没有在线指南解释此错误,但启用重新协商解决了问题,这对于来自其他编程语言的开发者可能是有用的信息。

问题内容

我尝试在 go 中发出一个简单的 http 请求,在直接按照指南进行操作后,我不断收到相同的错误:

本地错误:tls:无重新协商

我不太明白如何解释?我知道这在服务器上不是问题,因为当我从 python 调用相同的请求时,它返回正常。这是我的代码:

package main

import (
    "fmt"
    "net/http"
    "net/url"
    "strings"
    "time"
)

func main() {
    timeout := time.Duration(20 * time.Second)
    client := &http.Client{
        Timeout: timeout,
    }
    data := url.Values{
        "top":   {"10"},
        "lDate": {"2019-01-01"},
    }
    req, err := http.NewRequest("POST", "https://api.*********.com/AppAvailLoads?", strings.NewReader(data.Encode()))
    if err != nil {
        fmt.Println("Error in construction")
    }
    req.Header.Add("x-cdata-authtoken", "********")
    req.Header.Add("content-type", "application/x-www-form-urlencoded")
    resp, err := client.Do(req)
    if err != nil {
        fmt.Println("Error in request")
        fmt.Println(err)
    } else {
        fmt.Println(resp.Body)
        resp.Body.Close()
    }
}

解决方案


解决方案是启用 tls 重新协商(看图,我知道),这是 tls 包中的一个常量,如下所示:

tr := &http.Transport{
    TLSClientConfig: &tls.Config{
        Renegotiation: tls.RenegotiateOnceAsClient,
        // You may need this if connecting to servers with self-signed certificates
        // InsecureSkipVerify: true,
    },
}

client := &http.Client{
    Timeout:   timeout,
    Transport: tr,
}

这很奇怪,因为没有在线指南解释这一点或显示常见错误(例如 local 错误:tls:没有重新协商 )如何发生的示例。我希望这对来自其他语言的人有用,因为这不是人们通常处理的事情!

好了,本文到此结束,带大家了解了《TLS错误:未执行HTTP请求的重新协商》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

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