PHP批量检测并去除文件BOM头代码实例

    网站后台登陆的验证码不显示,我还以为是因为session没有写入权限呢,排查了一下不是目录权限问题,从网上查了说是BOM头的问题,用记事本打开的就会产生BOM头。附上清除bom头的小脚本,放到网站根目录执行就可以。

        
<?php
if (isset($_GET['dir'])) { //设置文件目录  
    $basedir = $_GET['dir'];
} else {
    $basedir = '.';
}  
 $auto = 1;
checkdir($basedir); 
 function checkdir($basedir)
{
    if ($dh = opendir($basedir)) {
        while (($file = readdir($dh)) !== false) {
            if ($file != '.' && $file != '..') {
                if (!is_dir($basedir . "/" . $file)) {
                    echo "filename: $basedir/$file " . checkBOM("$basedir/$file") . " <br>";
                } else {
                    $dirname = $basedir . "/" . $file;
                    checkdir($dirname);
                }
            }
        }
        closedir($dh);
    }
}
function checkBOM($filename)
{
    global $auto;
    $contents   = file_get_contents($filename);
    $charset[1] = substr($contents, 0, 1);
    $charset[2] = substr($contents, 1, 1);
    $charset[3] = substr($contents, 2, 1);
    if (ord($charset[1]) == 239 && ord($charset[2]) == 187 && ord($charset[3]) == 191) {
        if ($auto == 1) {
            $rest = substr($contents, 3);
            rewrite($filename, $rest);
            return ("<font color='red'>BOM found, automatically removed.</font>");
        } else {
            return ("<font color='red'>BOM found.</font>");
        }
    } else
        return ("BOM Not Found.");
} 
 function rewrite($filename, $data)
{
    $filenum = fopen($filename, "w");
    flock($filenum, LOCK_EX);
    fwrite($filenum, $data);
    fclose($filenum);
}
?>


评论