如上所述,当尝试读取这个简单的图像url时,php file_get_contents()函数甚至fopen()/ fread()组合都会卡住并超时:
http://pics.redblue.de/artikelid/GR/1140436/fee_786_587_png
但是同样的图像很容易被浏览器加载,最重要的是什么?
编辑:
根据评论中的要求,我显示了用于获取数据的函数:
function customRead($url)
{
$contents = '';
$handle = fopen($url, "rb");
$dex = 0;
while ( !feof($handle) )
{
if ( $dex++ > 100 )
break;
$contents .= fread($handle, 2048);
}
fclose($handle);
echo "\nbreaking due to too many calls...\n";
return $contents;
}
我也试过这个:
echo file_get_contents('http://pics.redblue.de/artikelid/GR/1140436/fee_786_587_png');
两者都给出了同样的问题
编辑:
正如评论中所建议我使用curl:
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.1 Safari/537.11');
$res = curl_exec($ch);
$rescode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch) ;
echo "\n\n\n[DATA:";
echo $res;
echo "]\n\n\n[CODE:";
print_r($rescode);
echo "]\n\n\n[ERROR:";
echo curl_error($ch);
echo "]\n\n\n";
这是结果:
[DATA:]
[CODE:0]
[ERROR:]