1--TEST-- 2Testing null byte injection in imagegd 3--SKIPIF-- 4<?php 5 if(!extension_loaded('gd')){ die('skip gd extension not available'); } 6?> 7--CLEAN-- 8$tempdir = sys_get_temp_dir(). '/php-gdtest'; 9foreach (glob($tempdir . "/test*") as $file ) { unlink($file); } 10rmdir($tempdir); 11--FILE-- 12<?php 13$image = imagecreate(1,1);// 1px image 14 15 16$tempdir = sys_get_temp_dir(). '/php-gdtest'; 17if (!file_exists($tempdir) && !is_dir($tempdir)) { 18 mkdir ($tempdir, 0777, true); 19} 20 21$userinput = "1\0"; // from post or get data 22$temp = $tempdir. "/test" . $userinput .".tmp"; 23 24echo "\nimagegd TEST\n"; 25imagegd($image, $temp); 26var_dump(file_exists($tempdir. "/test1")); 27var_dump(file_exists($tempdir. "/test1.tmp")); 28foreach (glob($tempdir . "/test*") as $file ) { unlink($file); } 29--EXPECTF-- 30imagegd TEST 31 32Warning: imagegd() expects parameter 2 to be a valid path, string given in %s on line %d 33bool(false) 34bool(false) 35