2015-04-28 39 views
3

我在我的PHP代码中遇到cURL请求的奇怪行为。 我在标准的WAMP Apache服务器上本地运行代码。 下面的代码:在PHP脚本中cURL请求的奇怪行为

$auth_info = "..."; 
$some_url = "..."; 
$channel = curl_init(); 
curl_setopt($channel, CURLOPT_URL, $some_url); 
curl_setopt($channel, CURLOPT_HTTPHEADER, 
    array("Authorization: BASIC " . base64_encode($auth_info)) 
); 
curl_setopt($channel, CURLOPT_RETURNTRANSFER, true); 
curl_setopt($channel, CURLOPT_HEADER, true); 
$response = curl_exec($channel); 
var_dump(curl_getinfo($channel)); 
$header_size = curl_getinfo($channel, CURLINFO_HEADER_SIZE); 
$header = substr($response, 0, $header_size); 
$body = substr($response, $header_size); 
var_dump($header); 
var_dump($body); 
curl_close($channel); 

如果我通过我的CLI执行这个小PHP代码片段(PowerShell的,因为我在Windows上运行),一切都很好,所有var_dumps工作,我可以看到$ he​​ader和$ body以及我所期望的所有内容和数据实际上都存在。

现在为奇怪的行为。如果我在任何浏览器上面的代码中打开脚本文件,它只是给我:

array (size=26) 
'url' => string 'the_url_here' (length=39) 
'content_type' => null 
'http_code' => int 0 
'header_size' => int 0 
'request_size' => int 0 
'filetime' => int -1 
'ssl_verify_result' => int 0 
'redirect_count' => int 0 
'total_time' => float 1.234 
'namelookup_time' => float 0 
'connect_time' => float 0.109 
'pretransfer_time' => float 0 
'size_upload' => float 0 
'size_download' => float 0 
'speed_download' => float 0 
'speed_upload' => float 0 
'download_content_length' => float -1 
'upload_content_length' => float -1 
'starttransfer_time' => float 0 
'redirect_time' => float 0 
'redirect_url' => string '' (length=0) 
'primary_ip' => string 'here_is_the_ip' (length=12) 
'certinfo' => 
    array (size=0) 
    empty 
'primary_port' => int 443 
'local_ip' => string 'here_is_my_ip' (length=13) 
'local_port' => int -> my_local_port_here 
boolean false 
boolean false 

我完全摸不着头脑,因为我不能看到脚本之间的差异与否有关的CLI开始, beeing由浏览器启动。有没有人有这个想法?

编辑注:如果我使用Guzzle作为请求,在CLI和浏览器中都可以正常工作。我仍然对cURL在这里引起问题的答案感兴趣。

+0

也许你需要一个正确的URL来运行测试? – Filype

+0

我怀疑你的CLI和WAMP指向不同的PHP安装。使用'php_info()'写一个快速页面,并查看php可执行文件所在的位置。 –

+0

我无法找到任何php_info()输出中的php.exe的直接路径,但我可以确认,该浏览器和CLI对于“加载的配置文件”具有不同的值。这可能已经是它了。 – plocks

回答

1

您是否尝试过记录Curl请求的详细输出?

通常情况下,我觉得这个要弄清楚什么是引擎盖下事情的最好方法...... https://stackoverflow.com/a/14436877/682754

也不像以前那样受欢迎,但这种方法看起来简单的实现,是有很多清洁... https://stackoverflow.com/a/26611776/682754

+1

你说得对。仔细调试请求会导致出现此错误:“SSL证书问题:证书链中的自签名证书”。使用这里提出的任一解决方案:http://stackoverflow.com/questions/6400300/https-and-ssl3-get-server-certificatecertificate-verify-failed-ca-is-ok可以帮助绕过这个问题。 我会接受你的答案,因为它实际上指向我的解决方案,即使它是间接的;-) – plocks

+1

很高兴听到你找到解决方案,证书也是我的许多卷曲问题的原因 – Carlton