php删除bom,PHP删除php文件中的BOM头

把下面文件保存成delbom.php放到网站根目录中访问就可以自动删除文件中的bom头(不会删除文件请放心使用)set_time_limit(0);

//要检查的后缀

$suffix = array('php', 'html');

if (isset($_GET['dir'])) {

$basedir = $_GET['dir'];

} else {

$basedir = '.';

}

$auto = 1;

checkdir($basedir);

function checkdir($basedir)

{

global $suffix;

if ($dh = opendir($basedir)) {

while (($file = readdir($dh)) !== false) {

if ($file != '.' && $file != '..') {

if (!is_dir($basedir . "/" . $file)) {

$kz = explode('.', $file);

$jc = isset($kz[1]) ? strtolower($kz[1]) : '';

if (!empty($kz) && in_array($jc, $suffix)) {

echo "filename: $basedir/$file " . checkBOM("$basedir/$file") . " 
";

}

} 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 ("BOM found, automatically removed._http://www.zhaokeli.com");

} else {

return ("BOM found.");

}

} else {

return ("BOM Not Found.");

}

}

function rewrite($filename, $data)

{

$filenum = fopen($filename, "w");

flock($filenum, LOCK_EX);

fwrite($filenum, $data);

fclose($filenum);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值