|
| 1 | +--TEST-- |
| 2 | +GHSA-74r9-qxhc-fx53: Out-of-bounds access in mbfl_name2encoding_ex() |
| 3 | +--CREDITS-- |
| 4 | +Akshay Jain (AkshayJainG) |
| 5 | +--EXTENSIONS-- |
| 6 | +mbstring |
| 7 | +--FILE-- |
| 8 | +<?php |
| 9 | + |
| 10 | +$encoding = "UTF-8\x00AAAAAAAAAAAAAAAA"; |
| 11 | +$alias = "binary\x00AAAAAAAAAAAAAAAA"; |
| 12 | +$var = 'foo'; |
| 13 | + |
| 14 | +function test($c) { |
| 15 | + try { |
| 16 | + $c(); |
| 17 | + } catch (Throwable $e) { |
| 18 | + echo $e::class, ': ', $e->getMessage(), "\n"; |
| 19 | + } |
| 20 | +} |
| 21 | + |
| 22 | +ini_set('mbstring.detect_order', $encoding); |
| 23 | +ini_set('mbstring.detect_order', $alias); |
| 24 | +ini_set('mbstring.http_output', $encoding); |
| 25 | +ini_set('mbstring.http_output', $alias); |
| 26 | + |
| 27 | +test(fn () => mb_convert_encoding('foo', $encoding, $encoding)); |
| 28 | +test(fn () => mb_convert_encoding('foo', $alias, $alias)); |
| 29 | +test(fn () => mb_detect_encoding('foo', $encoding)); |
| 30 | +test(fn () => mb_detect_encoding('foo', $alias)); |
| 31 | +test(fn () => mb_convert_variables($encoding, $alias, $var)); |
| 32 | +test(fn () => mb_detect_order($encoding)); |
| 33 | +test(fn () => mb_detect_order($alias)); |
| 34 | + |
| 35 | +?> |
| 36 | +--EXPECTF-- |
| 37 | +Warning: ini_set(): INI setting contains invalid encoding "UTF-8" in %s on line %d |
| 38 | + |
| 39 | +Warning: ini_set(): INI setting contains invalid encoding "binary" in %s on line %d |
| 40 | + |
| 41 | +Deprecated: ini_set(): Use of mbstring.http_output is deprecated in %s on line %d |
| 42 | + |
| 43 | +Deprecated: ini_set(): Use of mbstring.http_output is deprecated in %s on line %d |
| 44 | +ValueError: mb_convert_encoding(): Argument #3 ($from_encoding) contains invalid encoding "UTF-8" |
| 45 | +ValueError: mb_convert_encoding(): Argument #3 ($from_encoding) contains invalid encoding "binary" |
| 46 | +ValueError: mb_detect_encoding(): Argument #2 ($encodings) contains invalid encoding "UTF-8" |
| 47 | +ValueError: mb_detect_encoding(): Argument #2 ($encodings) contains invalid encoding "binary" |
| 48 | +ValueError: mb_convert_variables(): Argument #2 ($from_encoding) contains invalid encoding "binary" |
| 49 | +ValueError: mb_detect_order(): Argument #1 ($encoding) contains invalid encoding "UTF-8" |
| 50 | +ValueError: mb_detect_order(): Argument #1 ($encoding) contains invalid encoding "binary" |
0 commit comments