diff --git a/lib/http.c b/lib/http.c index 4eee832216..965b375037 100644 --- a/lib/http.c +++ b/lib/http.c @@ -2484,15 +2484,19 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) if(postsize) { /* Append the POST data chunky-style */ result = Curl_add_bufferf(req_buffer, "%x\r\n", (int)postsize); - if(CURLE_OK == result) + if(CURLE_OK == result) { result = Curl_add_buffer(req_buffer, data->set.postfields, (size_t)postsize); + if(CURLE_OK == result) + result = Curl_add_buffer(req_buffer, "\r\n", 2); + included_body = postsize + 2; + } } if(CURLE_OK == result) result = Curl_add_buffer(req_buffer, - "\x0d\x0a\x30\x0d\x0a\x0d\x0a", 7); - /* CR LF 0 CR LF CR LF */ - included_body = postsize + 7; + "\x30\x0d\x0a\x0d\x0a", 5); + /* 0 CR LF CR LF */ + included_body += 5; } if(result) return result; @@ -2526,8 +2530,8 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) /* Chunky upload is selected and we're negotiating auth still, send end-of-data only */ result = Curl_add_buffer(req_buffer, - "\x0d\x0a\x30\x0d\x0a\x0d\x0a", 7); - /* CR LF 0 CR LF CR LF */ + "\x30\x0d\x0a\x0d\x0a", 5); + /* 0 CR LF CR LF */ if(result) return result; } diff --git a/tests/data/test1333 b/tests/data/test1333 index 51ba75b4e4..a2ea301437 100644 --- a/tests/data/test1333 +++ b/tests/data/test1333 @@ -47,7 +47,6 @@ Accept: */* Transfer-Encoding: chunked Content-Type: application/x-www-form-urlencoded - 0 diff --git a/tests/data/test565 b/tests/data/test565 index fdf75a5f88..b8d12b45c6 100644 --- a/tests/data/test565 +++ b/tests/data/test565 @@ -79,7 +79,6 @@ Accept: */* Transfer-Encoding: chunked Content-Type: application/x-www-form-urlencoded - 0 POST /565 HTTP/1.1