参考: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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com