mirror of
https://github.com/php/php-src.git
synced 2025-08-15 13:38:49 +02:00
Merge branch 'PHP-8.4'
* PHP-8.4: Fix GH-17037: UAF in user filter when adding existing filter name due to incorrect error handling
This commit is contained in:
commit
f108eecf7c
2 changed files with 16 additions and 4 deletions
8
ext/standard/tests/filters/gh17037.phpt
Normal file
8
ext/standard/tests/filters/gh17037.phpt
Normal file
|
@ -0,0 +1,8 @@
|
|||
--TEST--
|
||||
GH-17037 (UAF in user filter when adding existing filter name due to incorrect error handling)
|
||||
--FILE--
|
||||
<?php
|
||||
var_dump(stream_filter_register('string.toupper', 'filter_string_toupper'));
|
||||
?>
|
||||
--EXPECT--
|
||||
bool(false)
|
|
@ -521,13 +521,17 @@ PHP_FUNCTION(stream_filter_register)
|
|||
fdat = ecalloc(1, sizeof(struct php_user_filter_data));
|
||||
fdat->classname = zend_string_copy(classname);
|
||||
|
||||
if (zend_hash_add_ptr(BG(user_filter_map), filtername, fdat) != NULL &&
|
||||
php_stream_filter_register_factory_volatile(filtername, &user_filter_factory) == SUCCESS) {
|
||||
RETVAL_TRUE;
|
||||
if (zend_hash_add_ptr(BG(user_filter_map), filtername, fdat) != NULL) {
|
||||
if (php_stream_filter_register_factory_volatile(filtername, &user_filter_factory) == SUCCESS) {
|
||||
RETURN_TRUE;
|
||||
}
|
||||
|
||||
zend_hash_del(BG(user_filter_map), filtername);
|
||||
} else {
|
||||
zend_string_release_ex(classname, 0);
|
||||
efree(fdat);
|
||||
RETVAL_FALSE;
|
||||
}
|
||||
|
||||
RETURN_FALSE;
|
||||
}
|
||||
/* }}} */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue