php 去除 ufeff,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
':'只检测文件BOM不执行去除BOM操作
';

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).'
';

}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并已自动去除');

}else{

return (' 找到BOM');

}

}else{

return (' 没有找到BOM');

}

}

function rewrite($filename,$data){

$filenum=fopen($filename,'w');

flock($filenum,LOCK_EX);

fwrite($filenum,$data);

fclose($filenum);

}

?>

原文链接:http://blog.jaekj.com/archives/1469.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值