http パッケージで単純な POST リクエストを送信するのに問題があります。
var http_client http.Client
req, err := http.NewRequest("POST", "http://login.blah", nil)
if err != nil {
return errors.New("Error creating login request: " + err.Error())
}
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
body := fmt.Sprintf("?username=%s&password=%s&version=%d", client.Username, client.Password, launcherVersion)
fmt.Println("Body:", body)
req.Body = ioutil.NopCloser(bytes.NewBufferString(body))
req.ParseForm()
resp, err := http_client.Do(req)
if err != nil {
return errors.New("Error sending login request: " + err.Error())
}
印刷物から正しい本文が表示されます。
Body: ?username=test&password=test&version=13
しかし、60 秒後に次のようになります。
Error sending login request: unexpected EOF
Wireshark でそれを見ると、すぐに送信されるリクエストがContent-Length
ボディなしで 0 であることがわかります。
POST / HTTP/1.1
Host: login.blah
User-Agent: Go http package
Content-Length: 0
Content-Type: application/x-www-form-urlencoded
Accept-Encoding: gzip