From: liubingrun Date: Tue, 16 Jul 2024 13:47:16 +0000 (-0400) Subject: Fix the handling of HEAD requests that do not comply with RFC standards X-Git-Tag: v18.2.5~283^2 X-Git-Url: http://git.apps.os.sepia.ceph.com/?a=commitdiff_plain;h=a799bf7c5fb01a194f77ff229a0609f5979671ca;p=ceph.git Fix the handling of HEAD requests that do not comply with RFC standards According to RFC 9110, The HEAD method is identical to GET except that the server MUST NOT send content in the response. And RFC 9112 indicates that Transfer-Encoding can be omitted in HEAD Response. The following HEAD OP is using chunked encoding and send the final chunk HEAD /bucket?uploads RGWListBucketMultiparts_ObjStore_S3 HEAD /bucket/abc?uploadId RGWListMultipart_ObjStore_S3 HEAD / RGWListBuckets_ObjStore_S3 Clients using persistent connections, such as nginx, will be unable to handle subsequent requests after processing such requests because the final chunk remains in the TCP byte stream, preventing the next HTTP response from being correctly parsed. Ref: https://www.rfc-editor.org/rfc/rfc9110.html#section-9.3.2 https://www.rfc-editor.org/rfc/rfc9112#section-6.1-9 Signed-off-by: liubingrun (cherry picked from commit e63101650d43a60ae21e6c682f77175690542869) --- diff --git a/src/rgw/rgw_rest.cc b/src/rgw/rgw_rest.cc index acf0ad9f88896..fa62e19a51196 100644 --- a/src/rgw/rgw_rest.cc +++ b/src/rgw/rgw_rest.cc @@ -394,6 +394,10 @@ void dump_content_length(req_state* const s, const uint64_t len) static void dump_chunked_encoding(req_state* const s) { + // omit transfer-encoding for HEAD requests so ChunkingFilter doesn't + // try to write the final chunk + if(s->op == OP_HEAD) + return; try { RESTFUL_IO(s)->send_chunked_transfer_encoding(); } catch (rgw::io::Exception& e) {