PHP批量去掉诡异的BOM \ufeff,消灭莫名其妙的小红点

最近在做一个项目时,出现了一个诡异的问题,就是AJAX从后台获取JSON数据时,怎么都识别不了JSON数据,打开浏览器的开发工具,发现原来是数据中出现了莫名其妙的小红点,如下图:

 
很明显就是这几个小红点惹的祸,直觉告诉我这几个小红点应该是空格之类的字符,可是接下来我使尽了各种手段,排除了程序中所有可能出现空格的地方,可是小红点依旧,快抓狂了,僵持了一天完全不知道到底是哪儿的问题。在调试中无意间把鼠标放到小红点上面发现居然有提示,此刻实在是太兴奋了,终于看到希望了,提示内容为:\UFEFF,终于找到原因了,原来是这个字符惹的祸,再顺藤摸瓜就简单了,最后在开源中国,找到了一段实用的代码,批量去BOM头:
 
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253<?php
header('content-Type: text/html; charset=utf-8');
if(isset($_GET['dir'])){ //设置文件目录,如果没有设置,则自动设置为当前文件所在目录
    $basedir=$_GET['dir'];
}else{
    $basedir='.';
}
$auto=1;/*设置为1标示检测BOM并去除,设置为0标示只进行BOM检测,不去除*/

echo '当前查找的目录为:'.$basedir.'当前的设置是:';
echo $auto?'检测文件BOM同时去除检测到BOM文件的BOM<br />':'只检测文件BOM不执行去除BOM操作<br />';

checkdir($basedir);
function checkdir($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{
                    $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);
}

?>





研究一个PHP项目的时候,今天项目突然打不开了。

  前几天还好好的,用Chrome看了下Response的内容,AJAX页面和普通HTML页面内容前面有一个红色的点。

 鼠标移上去,提示“\ufeff”。


 百度下,发现是BOM字符。


  前几天还好好的,难道是因为今天替换某些内容,导致的?


 从网上找了个php程序,扫描所有的文件,把BOM字符去掉。


 妈蛋,为啥总是有这么多不同的标准。


代码:

[php]  view plain  copy
  1. <?php  
  2. header('content-Type: text/html; charset=utf-8');  
  3. if(isset($_GET['dir'])){ //设置文件目录,如果没有设置,则自动设置为当前文件所在目录  
  4.     $basedir=$_GET['dir'];  
  5. }else{  
  6.     $basedir='.';  
  7. }  
  8. $auto=1;/*设置为1标示检测BOM并去除,设置为0标示只进行BOM检测,不去除*/  
  9.   
  10. echo '当前查找的目录为:'.$basedir.'当前的设置是:';  
  11. echo $auto?'检测文件BOM同时去除检测到BOM文件的BOM<br />':'只检测文件BOM不执行去除BOM操作<br />';  
  12.   
  13. checkdir($basedir);  
  14. function checkdir($basedir){  
  15.     if($dh=opendir($basedir)){  
  16.         while (($file=readdir($dh)) !== false){  
  17.             if($file != '.' && $file != '..'){  
  18.                 if(!is_dir($basedir.'/'.$file)){  
  19.                     echo '文件: '.$basedir.'/'.$file .checkBOM($basedir.'/'.$file).' <br>';  
  20.                 }else{  
  21.                     $dirname=$basedir.'/'.$file;  
  22.                     checkdir($dirname);  
  23.                 }  
  24.             }  
  25.         }  
  26.         closedir($dh);  
  27.     }  
  28. }  
  29. function checkBOM($filename){  
  30.     global $auto;  
  31.     $contents=file_get_contents($filename);  
  32.     $charset[1]=substr($contents,0,1);  
  33.     $charset[2]=substr($contents,1,1);  
  34.     $charset[3]=substr($contents,2,1);  
  35.     if(ord($charset[1])==239 && ord($charset[2])==187 && ord($charset[3])==191){  
  36.         if($auto==1){  
  37.             $rest=substr($contents,3);  
  38.             rewrite($filename,$rest);  
  39.             return (' <font color=red>找到BOM并已自动去除</font>');  
  40.         }else{  
  41.             return (' <font color=red>找到BOM</font>');  
  42.         }  
  43.     }else{  
  44.         return (' 没有找到BOM');  
  45.     }  
  46. }  
  47. function rewrite($filename,$data){  
  48.     $filenum=fopen($filename,'w');  
  49.     flock($filenum,LOCK_EX);  
  50.     fwrite($filenum,$data);  
  51.     fclose($filenum);  
  52. }  
  53. ?>  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值