我们都知道,一般我们在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数据。
然后我们在b.php中可以使用 1.curl方法;2.使用file_get_contents方法首先测试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格式!因此需要处理下。
|