未知字符/未知标记,json字符串

时间:2013-06-06 14:45:48

标签: php mysql ajax json encoding

这很直截了当。一方面我有一个PHP文件,另一方面是一个带有javascript脚本的html页面,用于获取json字符串并使用它做一些事情。

我确保我的所有文件都是UTF-8,我的数据库也是。

首次测试(可行):( PHP)

$array['fname'] = 'bob';
$array['lname'] = 'mozz';
$array['age'] = 20;
$array['email'] = 'test@test.com';
echo json_encode($array);

第二次测试(失败)(PHP)

try{
    $sql = 'SELECT * FROM blablabla';
    $results = $pdo->query($sql);

    $array = array();
    while($row = $results->fetch()){
        $array[] = array(
                'id' => $row['id'],
                'fname' => $row['fname'],
                'lname' => $row['lname'],
                'gender' => $row['gender'],
                'organization' => $row['organization'],
                'phoneLine1Label' => $row['phoneLine1Label'],
                'phoneLine1' => $row['phoneLine1'],
                'phoneLine1Ext' => $row['phoneLine1Ext'],
                'phoneLine2Label' => $row['phoneLine2Label'],
                'phoneLine2' => $row['phoneLine2'],
                'phoneLine2Ext' => $row['phoneLine2Ext'],
                'cellPhoneLabel' => $row['cellPhoneLabel'],
                'cellPhone' => $row['cellPhone'],
                'email' => $row['email']
        );
    }
    $json = json_encode($array);
    echo $json;
}catch(PDOException $e){}

我尝试将结果转换为十六进制,以查看未知字符是什么:

  • 当我直接从脚本打印时,我看到没有错(没有特殊字符)
  • 当我在我的控制台中打印结果时,它似乎很棒但是
  • 当我将结果复制到我的剪贴板并将其粘贴到utf8文件中时,它很棒
  • 当我将结果复制到ansi文件中时,我看到“?”在它的开头 enter image description here
  • 当我从控制台右键单击(在谷歌浏览器中)谷歌看到字符串开头的一个方块(眼睛看不见)

在我的javascript中;

<script>
    $(document).ready(function(){
        var query = {
            q: 'test',
            apikey: '1234567890'
        };
        $.post('script.php',query,function(data,status){
            switch(status){
                case 'success':
                    obj = JSON && JSON.parse(data) || $.parseJSON(data);
                    console.log(obj);
                break;
            }
        });
    });
</script>

当我从我的第一个PHP示例中插入脚本时,它可以工作,但不能从我的第二个PHP脚本中运行。它给我一个错误,说明我的json有未知的令牌。

我三重检查一切,我只是不知道它可能是什么。

修改

这是来自Fiddler网络调试器的捕获,它更奇怪:

enter image description here

编辑2 我甚至使用了修剪:

$json = json_encode($rows);
$fix = substr($json,7);
$fix = '[{"id":'.$fix;

但是当我收到它时,它仍会添加并且未知的字符添加开头。

编辑3(解决方案) 我清空文件,将其保存为没有BOM的utf8并粘贴内容并完成工作。我仍然不明白为什么会这样做。我确实理解BOM创建问题,但是包含我的PHP的文件是一个包含其他指令的控制器,那些基于编码的指令很完美。非常感谢任何人花时间研究我的问题,我真的很感激!

2 个答案:

答案 0 :(得分:2)

这闻起来就像你前面有一张BOM。保存没有BOM的PHP文件,应该这样做。 :)

请参阅:UTF-8 BOM signature in PHP files

答案 1 :(得分:0)

我清空文件,将其保存为没有BOM的utf8并粘贴内容并完成工作。我仍然不明白为什么会这样做。我确实理解BOM创建问题,但是包含我的PHP的文件是一个包含其他指令的控制器,那些基于编码的指令很完美。非常感谢任何人花时间研究我的问题,我真的很感激!