参考:https://stackoverflow.com/questions/31337891/net-http-http-contentlength-222-with-body-length-0golang
问题阐述:在使用 golang http 包发送 post 请求时出现报错,相似 http: ContentLength=355 with Body length 0。大意是 ConlentLength 设置了必定长度,可是在读取 Body 时,发现 Body 中没有内容。app
问题说明:post
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 内容。以上是我的理解,若有错误,请指教:-)url
解决办法:每次调用 Do 建立一个 req。spa