Looks like this issue was fixed in PHP 5.3 https://bugs.php.net/bug.php?id=39863PHP ã¯ããĄã¤ãĢãˇãšãã éĸéŖãŽæäŊãĢ C č¨čĒãŽéĸæ°ãäŊŋį¨ããĻãããŽã§ã null ãã¤ããŽåĻįãäēæããŦãããĄã§čĄããã¨ããããžãã C č¨čĒã§ã¯ null ãã¤ãã¯æååãŽįĩį̝ã襨ããŽã§ã null ãã¤ããåĢãæååãããŖãå ´åãĢ null ãã¤ãäģĨéãŽå åŽšã¯æååã¨ããĻåĻįãããžããã äģĨä¸ãĢãããŽåéĄãĢéĸããčåŧąæ§ãåĢããŗãŧãäžãį¤ēããžãã
äž1 null ãã¤ããĢ寞ããĻčåŧąãĒãšã¯ãĒãã
<?php
$file = $_GET['file']; // ããã§ "../../etc/passwd\0" ãæ¸Ąãããã¨ããžã
if (file_exists('/home/wwwrun/' . $file . '.php')) {
// file_exists 㯠true ãčŋããžããããã¯ãããĄã¤ãĢ /home/wwwrun/../../etc/passwd ãåå¨ããããã§ã
include '/home/wwwrun/'.$file.'.php';
// ããĄã¤ãĢ /etc/passwd ãã¤ãŗã¯ãĢãŧããããĻããžããžã
}
?>ããããŖãĻãããĄã¤ãĢãˇãšãã æäŊã§äŊŋį¨ãããæąæããããæååã¯ã ã¤ããĢéŠåãĢæ¤č¨ŧããĒããã°ãĒããžããã å ãģãŠãŽäžãæšč¯ããããŽãį¤ēããžãã
äž2 å ĨåãéŠåãĢæ¤č¨ŧããäž
<?php
$file = $_GET['file'];
// å¤ã¨ããĻä¸ããããå¯čŊæ§ãŽãããæåšãĒå¤ãŽä¸čϧãäŊæããžã
switch ($file) {
case 'main':
case 'foo':
case 'bar':
include '/home/wwwrun/include/' . $file . '.php';
break;
default:
include '/home/wwwrun/include/main.php';
}
?>Looks like this issue was fixed in PHP 5.3 https://bugs.php.net/bug.php?id=39863clean input of null bytes:
<?php
$clean = str_replace(chr(0), '', $input);
?>