diff --git a/sapi/cli/php_cli_server.c b/sapi/cli/php_cli_server.c
index 52b15728846..42bd36c4923 100644
--- a/sapi/cli/php_cli_server.c
+++ b/sapi/cli/php_cli_server.c
@@ -1980,49 +1980,51 @@ static zend_result php_cli_server_send_error_page(php_cli_server *server, php_cl
php_cli_server_content_sender_ctor(&client->content_sender);
client->content_sender_initialized = true;
- escaped_request_uri = php_escape_html_entities_ex((const unsigned char *) ZSTR_VAL(client->request.request_uri), ZSTR_LEN(client->request.request_uri), 0, ENT_QUOTES, NULL, /* double_encode */ 0, /* quiet */ 0);
+ if (client->request.request_method != PHP_HTTP_HEAD) {
+ escaped_request_uri = php_escape_html_entities_ex((const unsigned char *) ZSTR_VAL(client->request.request_uri), ZSTR_LEN(client->request.request_uri), 0, ENT_QUOTES, NULL, /* double_encode */ 0, /* quiet */ 0);
- {
- static const char prologue_template[] = "
%d %s";
- php_cli_server_chunk *chunk = php_cli_server_chunk_heap_new_self_contained(strlen(prologue_template) + 3 + strlen(status_string) + 1);
- if (!chunk) {
- goto fail;
+ {
+ static const char prologue_template[] = "%d %s";
+ php_cli_server_chunk *chunk = php_cli_server_chunk_heap_new_self_contained(strlen(prologue_template) + 3 + strlen(status_string) + 1);
+ if (!chunk) {
+ goto fail;
+ }
+ snprintf(chunk->data.heap.p, chunk->data.heap.len, prologue_template, status, status_string);
+ chunk->data.heap.len = strlen(chunk->data.heap.p);
+ php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
}
- snprintf(chunk->data.heap.p, chunk->data.heap.len, prologue_template, status, status_string);
- chunk->data.heap.len = strlen(chunk->data.heap.p);
- php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
- }
- {
- php_cli_server_chunk *chunk = php_cli_server_chunk_immortal_new(php_cli_server_css, sizeof(php_cli_server_css) - 1);
- if (!chunk) {
- goto fail;
+ {
+ php_cli_server_chunk *chunk = php_cli_server_chunk_immortal_new(php_cli_server_css, sizeof(php_cli_server_css) - 1);
+ if (!chunk) {
+ goto fail;
+ }
+ php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
}
- php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
- }
- {
- static const char template[] = "";
- php_cli_server_chunk *chunk = php_cli_server_chunk_immortal_new(template, sizeof(template) - 1);
- if (!chunk) {
- goto fail;
+ {
+ static const char template[] = "";
+ php_cli_server_chunk *chunk = php_cli_server_chunk_immortal_new(template, sizeof(template) - 1);
+ if (!chunk) {
+ goto fail;
+ }
+ php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
}
- php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
- }
- {
- php_cli_server_chunk *chunk = php_cli_server_chunk_heap_new_self_contained(strlen(content_template) + ZSTR_LEN(escaped_request_uri) + 3 + strlen(status_string) + 1);
- if (!chunk) {
- goto fail;
+ {
+ php_cli_server_chunk *chunk = php_cli_server_chunk_heap_new_self_contained(strlen(content_template) + ZSTR_LEN(escaped_request_uri) + 3 + strlen(status_string) + 1);
+ if (!chunk) {
+ goto fail;
+ }
+ snprintf(chunk->data.heap.p, chunk->data.heap.len, content_template, status_string, ZSTR_VAL(escaped_request_uri));
+ chunk->data.heap.len = strlen(chunk->data.heap.p);
+ php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
}
- snprintf(chunk->data.heap.p, chunk->data.heap.len, content_template, status_string, ZSTR_VAL(escaped_request_uri));
- chunk->data.heap.len = strlen(chunk->data.heap.p);
- php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
- }
- {
- static const char epilogue_template[] = "";
- php_cli_server_chunk *chunk = php_cli_server_chunk_immortal_new(epilogue_template, sizeof(epilogue_template) - 1);
- if (!chunk) {
- goto fail;
+ {
+ static const char epilogue_template[] = "";
+ php_cli_server_chunk *chunk = php_cli_server_chunk_immortal_new(epilogue_template, sizeof(epilogue_template) - 1);
+ if (!chunk) {
+ goto fail;
+ }
+ php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
}
- php_cli_server_buffer_append(&client->content_sender.buffer, chunk);
}
{
@@ -2053,14 +2055,18 @@ static zend_result php_cli_server_send_error_page(php_cli_server *server, php_cl
if (errstr) {
pefree(errstr, 1);
}
- zend_string_free(escaped_request_uri);
+ if (escaped_request_uri) {
+ zend_string_free(escaped_request_uri);
+ }
return SUCCESS;
fail:
if (errstr) {
pefree(errstr, 1);
}
- zend_string_free(escaped_request_uri);
+ if (escaped_request_uri) {
+ zend_string_free(escaped_request_uri);
+ }
return FAILURE;
} /* }}} */
@@ -2115,7 +2121,9 @@ static zend_result php_cli_server_begin_send_static(php_cli_server *server, php_
php_cli_server_content_sender_ctor(&client->content_sender);
client->content_sender_initialized = true;
- client->file_fd = fd;
+ if (client->request.request_method != PHP_HTTP_HEAD) {
+ client->file_fd = fd;
+ }
{
php_cli_server_chunk *chunk;
diff --git a/sapi/cli/tests/php_cli_server_013.phpt b/sapi/cli/tests/php_cli_server_013.phpt
index 8042219afe3..06a982b407c 100644
--- a/sapi/cli/tests/php_cli_server_013.phpt
+++ b/sapi/cli/tests/php_cli_server_013.phpt
@@ -93,6 +93,3 @@ Date: %s
Connection: close
Content-Type: text/html; charset=UTF-8
Content-Length: %d
-
-404 Not Found
-Not Found
The requested resource /main/foo/bar
was not found on this server.