Skip to content

Commit 041cbec

Browse files
committed
Merge branch 'PHP-7.4'
* PHP-7.4: Fix #77932: File extensions are case-sensitive
2 parents 08e6c20 + 68aa132 commit 041cbec

File tree

1 file changed

+11
-2
lines changed

1 file changed

+11
-2
lines changed

sapi/cli/php_cli_server.c

Lines changed: 11 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -372,7 +372,13 @@ static void append_essential_headers(smart_str* buffer, php_cli_server_client *c
372372

373373
static const char *get_mime_type(const php_cli_server *server, const char *ext, size_t ext_len) /* {{{ */
374374
{
375-
return (const char*)zend_hash_str_find_ptr(&server->extension_mime_types, ext, ext_len);
375+
char *ret;
376+
ALLOCA_FLAG(use_heap)
377+
char *ext_lower = do_alloca(ext_len + 1, use_heap);
378+
zend_str_tolower_copy(ext_lower, ext, ext_len);
379+
ret = zend_hash_str_find_ptr(&server->extension_mime_types, ext_lower, ext_len);
380+
free_alloca(ext_lower, use_heap);
381+
return (const char*)ret;
376382
} /* }}} */
377383

378384
PHP_FUNCTION(apache_request_headers) /* {{{ */
@@ -2216,9 +2222,12 @@ static int php_cli_server_dispatch_router(php_cli_server *server, php_cli_server
22162222
static int php_cli_server_dispatch(php_cli_server *server, php_cli_server_client *client) /* {{{ */
22172223
{
22182224
int is_static_file = 0;
2225+
const char *ext = client->request.ext;
22192226

22202227
SG(server_context) = client;
2221-
if (client->request.ext_len != 3 || memcmp(client->request.ext, "php", 3) || !client->request.path_translated) {
2228+
if (client->request.ext_len != 3
2229+
|| (ext[0] != 'p' && ext[0] != 'P') || (ext[1] != 'h' && ext[1] != 'H') || (ext[2] != 'p' && ext[2] != 'P')
2230+
|| !client->request.path_translated) {
22222231
is_static_file = 1;
22232232
}
22242233

0 commit comments

Comments
 (0)