我们都知道,一般我们在php项目中使用json_decode时,不会出现问题。
如果我们要想在A页面将数据库中的数据用json形式输出,例如:http://1.xxx.com/a.php
<span style="font-size:24px;"><?php
$sql="select * from ad where id=1 limit 1 ";
$query=mysql_query($sql);
$row=mysql_fetch_array($query);
$str=json_encode($row);
echo $str;
?></span>
结果如图:显示了正确的json数据。
首先测试curl
<span style="font-size:24px;"><?php
$url="http://1.xxx.com/a.php";
$ch = curl_init();
<span style="white-space:pre"> </span>curl_setopt($ch, CURLOPT_URL, $url);
<span style="white-space:pre"> </span>curl_setopt($ch, CURLOPT_HEADER, 0);
<span style="white-space:pre"> </span>curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
<span style="white-space:pre"> </span>$info=curl_exec($ch);
<span style="white-space:pre"> </span>curl_close($ch);
<span style="white-space:pre"> </span>echo "抓取的内容:".$info;
<span style="white-space:pre"> </span>echo "<br/>下面是json_decode处理后显示的:<br/>";
<span style="white-space:pre"> </span>$s=json_decode($info,true);
<span style="white-space:pre"> </span>echo "<pre>";
<span style="white-space:pre"> </span>print_r($s);
?></span>
我们会发现,出现的了故障:
竟然json_decode后无法显示!!!这是为何?
找了一天的原因,有猿友告诉我,是因为一个bom,导致json_decode无法运行,得到的结果是null,因此提供了一个方案。
<?php
$url="http://1.xxx.com/a.php";
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$info=curl_exec($ch);
curl_close($ch);
echo "抓取的内容:".$info;
echo "<br/>下面是json_decode处理后显示的:<br/>";
if(preg_match('/^\xEF\xBB\xBF/',$info))
{
$info = substr($info,3);
}
$info = json_decode(trim($info),true);
echo "<pre>";
print_r($info);
?>
到此,问题已经得到解决。。。主要的问题可能是由于数据库内容输出时显示的是带bom格式!因此需要处理下。