我在我的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工作,我可以看到$ header和$ 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在这里引起问题的答案感兴趣。
也许你需要一个正确的URL来运行测试? – Filype
我怀疑你的CLI和WAMP指向不同的PHP安装。使用'php_info()'写一个快速页面,并查看php可执行文件所在的位置。 –
我无法找到任何php_info()输出中的php.exe的直接路径,但我可以确认,该浏览器和CLI对于“加载的配置文件”具有不同的值。这可能已经是它了。 – plocks