mirror of
https://github.com/php/php-src.git
synced 2024-09-23 10:57:26 +00:00
a5a15965da
Since the constructor of DirectoryIterator and friends is supposed to accepts paths (i.e. strings without NUL bytes), we must not accept arbitrary strings.
32 lines
755 B
PHP
32 lines
755 B
PHP
--TEST--
|
|
Bug #78863 (DirectoryIterator class silently truncates after a null byte)
|
|
--FILE--
|
|
<?php
|
|
$dir = __DIR__ . '/bug78863';
|
|
mkdir($dir);
|
|
touch("$dir/bad");
|
|
mkdir("$dir/sub");
|
|
touch("$dir/sub/good");
|
|
|
|
$it = new DirectoryIterator(__DIR__ . "/bug78863\0/sub");
|
|
foreach ($it as $fileinfo) {
|
|
if (!$fileinfo->isDot()) {
|
|
var_dump($fileinfo->getFilename());
|
|
}
|
|
}
|
|
?>
|
|
--EXPECTF--
|
|
Fatal error: Uncaught UnexpectedValueException: DirectoryIterator::__construct() expects parameter 1 to be a valid path, string given in %s:%d
|
|
Stack trace:
|
|
#0 %s(%d): DirectoryIterator->__construct('%s')
|
|
#1 {main}
|
|
thrown in %s on line %d
|
|
--CLEAN--
|
|
<?php
|
|
$dir = __DIR__ . '/bug78863';
|
|
unlink("$dir/sub/good");
|
|
rmdir("$dir/sub");
|
|
unlink("$dir/bad");
|
|
rmdir($dir);
|
|
?>
|