Golang http post error : http: ContentLength=355 with Body length 0

纵饮孤独 提交于 2020-02-26 05:05:16

参考:https://stackoverflow.com/questions/31337891/net-http-http-contentlength-222-with-body-length-0

问题阐述:在使用 golang http 包发送 post 请求时出现报错,类似 http: ContentLength=355 with Body length 0。大意是 ConlentLength 设置了一定长度,但是在读取 Body 时,发现 Body 中没有内容。

问题说明:

func Post(URL string, form url.Values, cl *http.Client) ([]byte, error) {
  body := form.Encode() // req, err := http.newRequest("POST", URL, strings.NewReader(body))  //执行报错ContentLength=355 with Body length 0 
  for i := 0; i < 10; i++ {
    req, err := http.NewRequest("POST", URL, strings.NewReader(body)) //执行正确      
    if err != nil {
        log.Error(err)
        return nil, err
    }
    req.Header.Set("User-Agent", ua)
    req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
    rsp, err := cl.Do(req)
    if err == nil {
        defer rsp.Body.Close()
        b, err := ioutil.ReadAll(rsp.Body)
        if err != nil {
            log.Error(err)
            return nil, err
        }
        return b, nil
    }

    if !IsErrorProxy(err) {
        return nil, err
    }

    log.Errorf("Proxy is slow or down ")
    time.Sleep(6 * time.Second)
  }
  return nil, fmt.Errorf("after 10 tries error: %v", err)
}

问题的原因 req 创建不能放到 for 循环外,因为 Do 方法会关闭 req 中的 Body 读取,因此同一个 req 再次传参给 Do 时,Body 的读方法已经关闭,不能读到 Body 内容。以上是个人理解,如有错误,请指教:-)

解决办法:每次调用 Do 创建一个 req。

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!