look321 发表于 2018-9-21 06:14:11

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

  参考: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。


页: [1]
查看完整版本: Golang http post error : http: ContentLength=355 with Body length 0