BOM是用来判定文本文件是哪一种Unicode编码的标记,其自身是一个Unicode字符("\uFEFF"),位于文本文件头部,BOM正本不影响代码的剖析,然则php除外,PHP会剖析BOM,会输出在页面里,形成前端有占位发作构造位移,如果不熟悉的php BOM 就会对这个平白多出来的工具感应莫明其妙。
我们去掉网站php文件里的BOM信息呢
编纂器能够无糊口生涯bom文件,utf-8和utf-8 with bom ,要糊口生涯了bom文件 php会报错 namespace 必需是第一行的代码,现在是bom信息是第一行,虽然你看不到然则他就是在第一行
我们如何样经由过程代码的情势批量的去掉文件的bom信息
在网站根目次下新建一个nobomb.php的文件,
营销型做网站公司,文件的代码为以下内容。主要办理模板多出空的内容、考证码不浮现等题目。然后在浏览器间接会见运转nobom.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") . "
";
} 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.");
} 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);
}
运转下面的代码就能够断根文件的bom信息
下面的截图看是没有发明带有bom的文件的,有bom的文件 会泛起字体加赤色。
去掉后会见 网站会见一般