curl_exec导致php脚本停止做任何事情

时间:2011-02-14 17:29:18

标签: php curl

当我在特定网址上运行curl时,网站停止响应并且不会生成错误,尽管我已将错误报告设置为开启。我已经尝试将卷曲超时设置为低值,然后它会生成错误,所以我知道它不会超时。

我想知道的主要事情是,怎么会发生这种情况,我怎么能找出原因?

我正在尝试访问的网址是对Factual API的调用,以及我在这里使用的网址

  

http://api.factual.com/v2/tables/bi0eJZ/read?api_key=*apikey*&filters= { “类别”: “汽车”, “$ LOC”:{ “内$”:{ “$中心”:[[41,-74],80467.2]}})

将其放入浏览器时可以正常工作。如果您将纬度和经度更改为基本上任何其他值,则PHP脚本将按预期工作。

error_reporting(E_ALL);
ini_set('display_errors', '2');
$url="http://api.factual.com/v2/tables/bi0eJZ/read?api_key=*apikey*&filters={\"category\":\"Automotive\",\"\$loc\":{\"\$within\":{\"\$center\":[[41,-74],80467.2]}},\"website\":{\"\$blank\":false}}";
Echo "\n\n1";

$ch = curl_init($url);
Echo 2;
curl_setopt($ch, CURLOPT_HEADER, 0);
Echo 3;
curl_setopt($ch, CURLOPT_POST, 1);
Echo 4;
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT,15);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT,30);
Echo 5;
$output = curl_exec($ch) or die("hhtrjrstjsrjt".curl_error($ch));   
Echo 6;
curl_close($ch);
Echo "out: ".$output;

7 个答案:

答案 0 :(得分:3)

您的PHP配置文件看起来有些错误。

要修复错误,您必须修改php.ini文件。

要在开发模式下显示错误,请将error_reporting值更改为E_ALL

error_reporting=E_ALL

然后你必须启用cURL扩展。 要在php.ini中启用它,您必须取消注释以下行:

extension=php_curl.dll

一旦您编辑了这些值,请不要忘记重新启动您的网络服务器(Apache或Nginx)

我也同意我的同事们,你应该url_encode你的JSON字符串。

从我的观点来看,代码应该是:

<?php
ini_set('display_errors', '1');
error_reporting(E_ALL);

$apiKey = '*apikey*';
$filters = '{"category":"Automotive","$loc":{"$within":{"$center":[[41,-74],80467.2]}},"website":{"$blank":false}}';
$params = '?api_key=' . $apiKey . '&filters=' . url_encode($filters);

$url = 'http://api.factual.com/v2/tables/bi0eJZ/read';
$url .= $params;

$ch = curl_init($url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 15);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 30);
$output = curl_exec($ch) or die("cURL Error" . curl_error($ch));   
curl_close($ch);

echo "out: " . $output;

修改

另一种方法可能是使用Factual API的官方PHP驱动程序: Official PHP driver for the Factual API

它提供Debug Mode cURL Debug OutputException Debug Output

答案 1 :(得分:2)

在我的情况下,卷曲失败的原因是托管服务提供商用Litespeed取代了Apache,而litespeed在卷曲请求期间终止了这个过程。

php.ini设置没有解决这个问题,因为lsphp每次都会在30秒后终止。

我们进行了长时间的聊天,我确信他们的服务器实际上已经损坏(最终)。

为其他可能遇到类似或相关问题的人提供更清晰的信息:
我的PHP脚本正在运行,并且PHP中没有记录任何错误,因为整个PHP进程(包括错误记录器)都被Web服务器终止。

答案 2 :(得分:2)

您的网址不是url_encoded,因为CURL是一个外部应用程序必须转义,您的浏览器将自动url_encode params在URL上,但是你可能会破坏服务器上的卷曲并且它正在停止。

尝试更改此内容:

$url="http://api.factual.com/v2/tables/bi0eJZ/read?api_key=*apikey*&filters={\"category\":\"Automotive\",\"\$loc\":{\"\$within\":{\"\$center\":[[41,-74],80467.2]}},\"website\":{\"\$blank\":false}}";

为:

$url_filters = '{"category":"Automotive","$loc":{"$within":{"$center":[[41,-74],80467.2]}},"website":{"$blank":false}}';

$url="http://api.factual.com/v2/tables/bi0eJZ/read?api_key=*apikey*&filters=".urlencode($url_filters);

但是我确实有一些问题,你的电话是否正确?礼物的关键&#34; $ loc&#34;那是对的吗?

已更新,无需反斜杠所有单引号都不支持变量替换,并允许双引号而不转义它们

答案 3 :(得分:2)

之前我曾使用过vanilla PHP的CURL调用。 CURL调用是curl类的一部分。正如其他用户所建议的那样,url_encode($url)函数将准备字符串以供此特定类使用。如果你不运行它,那么你可以传入会破坏处理程序的URL(例如,通过使用无效字符或URL语法)。

除此之外,您似乎正在尝试将JSON对象直接传递到页面的URL中。我不认为在这样的curl调用中使用JSON包是最佳做法。如果您要这样做,请参阅此页面:How to POST JSON data with Curl from Terminal/Commandline to Test Spring REST?

答案 4 :(得分:1)

此代码仅用于测试,只需根据我的代码修改代码

<?php   

$useragent = 'Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/534.10 (KHTML, like Gecko)
Chrome/8.0.552.224: Safari/534.10'; // notice this
$url="http://api.factual.com/v2/tables/bi0eJZ/read?api_key=*apikey*&filters={\"category\":\"Automotive\",\"\$loc\":{\"\$within\":{\"\$center\":[[41,-74],80467.2]}},\"website\":{\"\$blank\":false}}";
$ch = curl_init(); // notice this

curl_setopt($ch, CURLOPT_URL, $url); // notice this
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);

curl_setopt($ch, CURLOPT_USERAGENT, $useragent);




$contents = curl_exec($ch);
echo $contents;
?>

答案 5 :(得分:1)

为了将来的利益:

  1. urlencode用于查询参数作为过滤器参数 包含许多对URL不安全/有效的字符

  2. 使用curl_getinfo()查看有关http_code和的信息 其他有用的信息。

答案 6 :(得分:0)

脚本停止做任何事情,你可以在这里找到它:

http://php.net/manual/en/function.set-time-limit.php

摘录:

set_time_limit()函数和配置指令max_execution_time仅影响脚本本身的执行时间。在确定脚本运行的最长时间时,不会包括在执行脚本之外发生的任何活动,例如使用system()的系统调用,流操作,数据库查询等。在测量时间真实的Windows上,情况并非如此。

基本上,curl会阻止所有的PHP脚本,基本上唯一真正运行的是curl,所以如果它永远阻塞,你的网站就不会响应,这就是为什么你需要使用超时......

如何避免它,只需使用超时......