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

參考: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

相關文章
相關標籤/搜索