iliaa Sun Jun 3 16:19:55 2007 UTC Modified files: /php-src/tests/basic 027.phpt /php-src/main php_variables.c Log: MFB: Improved fix for MOPB-02-2007 http://cvs.php.net/viewvc.cgi/php-src/tests/basic/027.phpt?r1=1.1&r2=1.2&diff_format=u Index: php-src/tests/basic/027.phpt diff -u /dev/null php-src/tests/basic/027.phpt:1.2 --- /dev/null Sun Jun 3 16:19:55 2007 +++ php-src/tests/basic/027.phpt Sun Jun 3 16:19:55 2007 @@ -0,0 +1,35 @@ +--TEST-- +Handling of max_input_nesting_level being reached +--INI-- +magic_quotes_gpc=0 +always_populate_raw_post_data=0 +display_errors=0 +max_input_nesting_level=10 +track_errors=1 +log_errors=0 +--SKIPIF-- +<?php if (php_sapi_name()=='cli') echo 'skip'; ?> +--POST-- +a=1&b=ZYX&c[][][][][][][][][][][][][][][][][][][][][][]=123&d=123&e[][]][]=3 +--FILE-- +<?php +var_dump($_POST, $php_errormsg); +?> +--EXPECT-- +array(4) { + ["a"]=> + string(1) "1" + ["b"]=> + string(3) "ZYX" + ["d"]=> + string(3) "123" + ["e"]=> + array(1) { + [0]=> + array(1) { + [0]=> + string(1) "3" + } + } +} +string(124) "Unknown: Input variable nesting level more than allowed 10 (change max_input_nesting_level in php.ini to increase the limit)" http://cvs.php.net/viewvc.cgi/php-src/main/php_variables.c?r1=1.138&r2=1.139&diff_format=u Index: php-src/main/php_variables.c diff -u php-src/main/php_variables.c:1.138 php-src/main/php_variables.c:1.139 --- php-src/main/php_variables.c:1.138 Wed Mar 28 09:13:55 2007 +++ php-src/main/php_variables.c Sun Jun 3 16:19:55 2007 @@ -17,7 +17,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: php_variables.c,v 1.138 2007/03/28 09:13:55 tony2001 Exp $ */ +/* $Id: php_variables.c,v 1.139 2007/06/03 16:19:55 iliaa Exp $ */ #include <stdio.h> #include "php.h" @@ -133,8 +133,22 @@ int new_idx_len = 0; if(++nest_level > PG(max_input_nesting_level)) { + HashTable *ht; /* too many levels of nesting */ - php_error_docref(NULL TSRMLS_CC, E_ERROR, "Input variable nesting level more than allowed %ld (change max_input_nesting_level in php.ini to increase the limit)", PG(max_input_nesting_level)); + + if (track_vars_array) { + ht = Z_ARRVAL_P(track_vars_array); + } else if (PG(register_globals)) { + ht = EG(active_symbol_table); + } + + zend_hash_del(ht, var, var_len + 1); + zval_dtor(val); + + if (!PG(display_errors)) { + php_error_docref(NULL TSRMLS_CC, E_WARNING, "Input variable nesting level more than allowed %ld (change max_input_nesting_level in php.ini to increase the limit)", PG(max_input_nesting_level)); + } + return; } ip++; @@ -150,9 +164,9 @@ /* PHP variables cannot contain '[' in their names, so we replace the character with a '_' */ *(index_s - 1) = '_'; - index_len = var_len = 0; + index_len = 0; if (index) { - index_len = var_len = strlen(index); + index_len = strlen(index); } goto plain_var; return; @@ -818,8 +832,6 @@ { char *p; unsigned char _gpc_flags[5] = {0, 0, 0, 0, 0}; - zval *dummy_track_vars_array = NULL; - zend_bool initialized_dummy_track_vars_array=0; zend_bool jit_initialization = PG(auto_globals_jit); struct auto_global_record { char *name; @@ -893,15 +905,9 @@ continue; } if (!PG(http_globals)[i]) { - if (!initialized_dummy_track_vars_array) { - ALLOC_ZVAL(dummy_track_vars_array); - array_init(dummy_track_vars_array); - INIT_PZVAL(dummy_track_vars_array); - initialized_dummy_track_vars_array = 1; - } else { - dummy_track_vars_array->refcount++; - } - PG(http_globals)[i] = dummy_track_vars_array; + ALLOC_ZVAL(PG(http_globals)[i]); + array_init(PG(http_globals)[i]); + INIT_PZVAL(PG(http_globals)[i]); } PG(http_globals)[i]->refcount++;
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php