今天才发现上传到阿里云上的网页有点怪怪,头顶上有空行,见下图,而在本地电脑搭建的服务器的同样代码的网页却是没有的。怎么会事?!

        121212.png

        析事必究其源。用chrome浏览器右键“审查元素”,查看实时实际源码,发现head里面的meta、link等全都跑到body里去了,而本地电脑服务器的正常的,但是右键“查看网页源代码”,发现代码又是正常的,head里面有meta、link等,和源文件一样。说明不是代码写错,不是CSS的问题。

        有事找度娘。百度下网上还真有不少这样网页顶部有空行的案例,除了偶尔说是CSS问题外,都说是BOM的问题,网页文件要保存为utf-8(无BOM)格式。原因是IE不能正常解析包含多个UTF8 BOM 标记的页面,直接替换成实际显示的回车,因此会出现顶部的空行。解决当然是把网页文件改为utf-8(无BOM)格式了,用UE就行,问题是要改所有,网站上有几十上百个文件,所有。。。

        幸好找到一个大牛贴,提供了个程序能将网站所有文件自动的都改为utf-8(无BOM)格式。程序如下,使用方法是将程序的PHP文件放到网站目录,浏览器访问这个PHP就行了。


<?php 
$basedir = str_replace('/clearBOM.php','',str_replace('\\','/',dirname(__FILE__)));
$auto = 1;
checkdir($basedir);
function checkdir($basedir){
	if ($dh = opendir($basedir)) {
		while (($file = readdir($dh)) !== false) {
			if ($file != '.' && $file != '..'){
				if (!is_dir($basedir.'/'.$file)) {
					$filename = $basedir.'/'.$file;
					echo 'filename:'.$basedir.'/'.$file.checkBOM($filename).'<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);
}
?>

(提供下这个程序的TXT下载:clearBOM.txt

        改好后就一切正常啦:

        3424.png