今天在改网站时候发现这个问题,于是就在百度上找了半天(其实不知道这个该如何百度),最后还是让我找到了解决方法了。
鼠标移到到红点上出现了\ufeff字符,百度了一下,发现这是BOM头的数据
于是想办法去过滤他,我正则测试了半天没有问题,可是一上PHP 代码就不行,于是继续百度。
我将最终的方法贴出来给大家
将下面的php放在本地项目运行一下,批量处理非法字符(浏览器直接运行一下即可)
<?php header('content-Type: text/html; charset=utf-8'); $auto=1;/*设置为1标示检测BOM并去除,设置为0标示只进行BOM检测,不去除*/ $basedir='.'; $loop=true;//www.phpernote.com echo '当前查找的目录为:'.$basedir.'当前的设置是:'; echo '(1)',$loop?'检查当前目录以及当前目录的子目录':'只针对当前目录进行检测'; echo '(2)',$auto?'检测文件BOM同时去除检测到BOM文件的BOM<br />':'只检测文件BOM不执行去除BOM操作<br />'; checkdir($basedir,$loop); function checkdir($basedir='',$loop=true){ $basedir=empty($basedir)?'.':$basedir; if($dh=opendir($basedir)){ while (($file=readdir($dh))!==false){ if($file!='.'&&$file!='..'){ if(!is_dir($basedir.'/'.$file)){ echo '文件: '.$basedir.'/'.$file .checkBOM($basedir.'/'.$file).' <br>'; }else{ if(!$loop) continue; $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并已自动去除</font>'); }else{ return (' <font color=red>找到BOM</font>'); } }else{ return (' 没有找到BOM'); } } function rewrite($filename,$data){ $filenum=fopen($filename,'w'); flock($filenum,LOCK_EX); fwrite($filenum,$data); fclose($filenum); }
发表评论