PHP window2003服务和2008服务器上传个别文件访问报错

PHP 上传更新个别文件导致访问所有页面报错误


     业余搞PHP接些业余单做下,框架用PHP主流ThinkPHP,但是有一次客户叫我添加一个小功能,只是一个单纯的页面,我改好后上传,但是重启IIS服务器,问题就来了,所有页面全部报错,做的是一个景区官网,五一前一天奔溃,我也奔溃了,找了了很多资料,基本没用,最后发现不是代码问题,是上传时候,万恶的BOM导致整个网站报错。



什么是bom头?
在utf-8编码文件中BOM在文件头部,占用三个字节,用来标示该文件属于utf-8编码,现在已经有很多软件识别bom头,但是还有些不能识别bom头,比如PHP就不能识别bom头,这也是用记事本编辑utf-8编码后执行就会出错的原因了。


去除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);  
}  
?>  

这段代码可以简单命名一个文件夹放在网站根目录,万一出现,用HTTP激活,代码会自动遍历所有文件并且把BOM头去掉。更加不用担心更新个别文件在某些服务器上出现BOM错误!





总结不好多多担待,文章只单纯个人总结,如不好勿喷,技术有限,有错漏麻烦指正提出。本人QQ:373965070




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值