diff options
author | Felipe Pena <felipe@php.net> | 2011-06-27 23:18:26 +0000 |
---|---|---|
committer | Felipe Pena <felipe@php.net> | 2011-06-27 23:18:26 +0000 |
commit | 6cc66ef9647085eba63bbd6aba028d46edc2584f (patch) | |
tree | 38af4c00e08d3661aae1c8ce1246ee8830a0c796 /sapi/cli/php_cli_server.c | |
parent | eb9093160ffdcdd31366f14351cc215e35c9dd0d (diff) | |
download | php-git-6cc66ef9647085eba63bbd6aba028d46edc2584f.tar.gz |
- Fixed crash on invalid addr:port (Chris Jones, Felipe)
Diffstat (limited to 'sapi/cli/php_cli_server.c')
-rw-r--r-- | sapi/cli/php_cli_server.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/sapi/cli/php_cli_server.c b/sapi/cli/php_cli_server.c index f7b4d8ad5b..f8c68148f8 100644 --- a/sapi/cli/php_cli_server.c +++ b/sapi/cli/php_cli_server.c @@ -360,6 +360,9 @@ static int sapi_cli_server_startup(sapi_module_struct *sapi_module) /* {{{ */ static int sapi_cli_server_ub_write(const char *str, uint str_length TSRMLS_DC) /* {{{ */ { php_cli_server_client *client = SG(server_context); + if (!client) { + return 0; + } if (client->capturing) { php_cli_server_chunk *chunk = php_cli_server_chunk_heap_new_self_contained(str_length); if (!chunk) { @@ -400,7 +403,7 @@ static int sapi_cli_server_send_headers(sapi_headers_struct *sapi_headers TSRMLS sapi_header_struct *h; zend_llist_position pos; - if (client->capturing || SG(request_info).no_headers) { + if (client == NULL || client->capturing || SG(request_info).no_headers) { return SAPI_HEADER_SENT_SUCCESSFULLY; } @@ -1506,7 +1509,9 @@ static int php_cli_server_send_error_page(php_cli_server *server, php_cli_server php_cli_server_client_begin_capture(client); zend_try { php_info_print_style(TSRMLS_C); - php_cli_server_buffer_append(&client->content_sender.buffer, client->capture_buffer.first); + if (client->capture_buffer.first) { + php_cli_server_buffer_append(&client->content_sender.buffer, client->capture_buffer.first); + } client->capture_buffer.first = client->capture_buffer.last = NULL; } zend_catch { err = 1; @@ -1785,7 +1790,11 @@ static int php_cli_server_ctor(php_cli_server *server, const char *addr, const c php_socket_t server_sock = SOCK_ERR; host = pestrdup(addr, 1); - if (!host) { + if (!host || *host == ':' ) { + if (host) { + pefree(host, 1); + } + fprintf(stderr, "Invalid built-in web-server addr:port argument\n"); return FAILURE; } |