這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
參考: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。