zoukankan      html  css  js  c++  java
  • bom头惹的祸!

    今天使用json_decode函数解析json数据一直出错,最后发现j用浏览器开发者工具发现json数据前面多了个$#65279,查询得知是bom头;

    网上找的去除bom头的代码如下:

    <?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);
    }
    ?>
  • 相关阅读:
    Javascript | 模拟mvc实现点餐程序
    DataTables实现按分组小计
    [Webcast]Silverlight探秘系列课程
    python 环境搭建
    MailMessage
    WebRequest
    消息队列(Message Queue)
    c# 缓存
    c# 反射
    数据库连接超时
  • 原文地址:https://www.cnblogs.com/lilili/p/5127005.html
Copyright © 2011-2022 走看看