php curl后json_decode无法显示的问题

1 篇文章 0 订阅
1 篇文章 0 订阅
我们都知道,一般我们在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格式!因此需要处理下。


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您好!根据您提供的代码,您想通过POST请求向"https://query2.finance.yahoo.com/v1/finance/screener"发送数据,并获取响应结果。为了确保请求数据正确,您可以将请求数据编码为JSON格式,并在请求头中指定Content-Type为application/json。以下是修改后的代码示例: ```php $curl = curl_init(); $url = "https://query2.finance.yahoo.com/v1/finance/screener?crumb=XpTM.zvF16Z&lang=en-US&region=US&formatted=true&corsDomain=finance.yahoo.com"; // 替换为实际请求URL $data = array( "offset" => 6325, "size" => 25, "sortField" => "dayvolume", "sortType" => "desc", "quoteType" => "equity", "query" => array( "operator" => "eq", "operands" => array("region", "in") ), "userId" => "", "userIdType" => "guid" ); $jsonData = json_encode($data); curl_setopt($curl, CURLOPT_URL, $url); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_POST, true); curl_setopt($curl, CURLOPT_POSTFIELDS, $jsonData); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/json')); $response = curl_exec($curl); print_r($response); curl_close($curl); exit; ``` 这样,请求数据将被正确编码为JSON格式,并作为POST请求发送到指定URL。请注意,我已经注释了您提供的`$dd=json_decode(curl_exec($curl),true);`行,因为您在此行之前已经使用`print_r($response);`打印了响应结果。 希望能帮到您!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值