8

我在我的项目中使用 CURL,它在本地工作正常,但如果我使用相同的代码它不执行,我试图调试它。输出如下:

Took 0 seconds to send a request to https://www.google.co.in

我使用了以下示例代码:

$handle=curl_init('https://www.google.co.in');
curl_setopt($handle, CURLOPT_VERBOSE, true);
curl_setopt($handle, CURLOPT_RETURNTRANSFER, true);
curl_setopt($handle, CURLOPT_SSL_VERIFYPEER, false);
$content = curl_exec($handle);

if(!curl_errno($handle))
{
    $info = curl_getinfo($handle);

    echo '<br/> Took ' . $info['total_time'] . ' seconds to send a request to ' . $info['url'];
}
else
{
    echo 'Curl error: ' . curl_error($handle);
}

echo $content;

问题出在服务器上,我不知道在 php.ini 中启用什么。

请注意,在服务器 CURL 和 SSL 中已启用。如果有人遇到类似问题,请分享解决方案。

4

2 回答 2

9

在这种情况下,对我来说,问题是我得到的是 302 重定向,而不是实际的 get 请求。

CURLOPT_VERBOSE从这个答案打开后

$fp = fopen(dirname(__FILE__).'/errorlog.txt', 'w');
curl_setopt($ch, CURLOPT_VERBOSE, 1);
curl_setopt($ch, CURLOPT_STDERR, $fp);

我得到以下内容errorlog.txt

* Connected to www.example.com (X.X.X.X) port 443 (#0)
* successfully set certificate verify locations:
*   CAfile: none
  CApath: /etc/ssl/certs
* SSL connection using ECDHE-RSA-AES128-GCM-SHA256
* Server certificate:
*        subject: OU=Domain Control Validated; OU=COMODO SSL; CN=www.example.com
*        start date: 2016-04-28 00:00:00 GMT
*        expire date: 2018-04-08 23:59:59 GMT
*        issuer: C=GB; ST=Greater Manchester; L=Salford; O=COMODO CA Limited; CN=COMODO RSA Domain Validation Secure Server CA
*        SSL certificate verify ok.
> GET /path/to/file.php
HTTP/1.1^M
Host: www.example.com^M
Accept: */*^M
^M
< HTTP/1.1 302 Found^M
* Server nginx is not blacklisted
< Server: nginx^M
< Date: Tue, 20 Sep 2016 02:06:45 GMT^M
< Content-Type: text/html^M
< Transfer-Encoding: chunked^M
< Connection: keep-alive^M
< X-Powered-By: PHP/5.5.9-1ubuntu4.19^M
< Location: https://www.example.com/other/url/^M
< ^M
* Connection #0 to host www.example.com left intact

注意

  1. HTTP/1.1 302 Found(应该只是 200 响应)
  2. Location: https://www.example.com/other/url/GET请求 URL不同
于 2016-09-20T02:21:48.430 回答
4

问题:

功能curl_exec被禁用。该怎么办?

解决方案:

为了消除此错误消息,您需要执行以下操作之一

  1. 从文件中删除curl_exec字符串disable_functionsphp.ini
  2. 如果您无权访问该php.ini文件,请让您的托管服务提供商删除上面的字符串
  3. 将托管服务提供商更改为允许运行该curl_exec功能的服务提供商。

以下是 中的条目示例php.ini

更改自:

disable_functions = exec,passthru,shell_exec,system,proc_open,popen,curl_exec,curl_multi_exec,show_source,eval,posix_getpwuid

至:

disable_functions = exec,passthru,shell_exec,system,proc_open,popen,curl_multi_exec,show_source,eval,posix_getpwuid

资料来源:http ://tipstricks.itmatrix.eu/?p=1365

于 2013-05-27T08:59:36.380 回答