使用PHP下载类似50+ PDF文件的正确方法是什么?
下面是我使用的代码:
$fp = fopen("test.pdf", 'w');
$ch = curl_init();
curl_setopt($ch,CURLOPT_PROXY,"http://test:123");
curl_setopt($ch,CURLOPT_PROXYPORT,123);
curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, 0);
curl_setopt ($ch, CURLOPT_TIMEOUT, 500);
curl_setopt($ch,CURLOPT_URL,"http://download/test.pdf");
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_exec($ch);
curl_close($ch);
fclose($fp);问题是,有时2-3个PDF文件没有正确下载(0-1字节大小).知道它为什么不稳定吗?我必须在上面的代码中包括其他内容吗?
发布于 2013-02-19 11:29:26
一般情况下,Web请求可能非常不可靠,即使是来自浏览器和良好的连接。这里可能会出现一些问题,从拒绝连接的远程站点到从多个位置同时执行php文件。看一下:
http://www.php.net/manual/en/function.curl-error.php
尝试在某个地方打印用于curl_exec分析的错误消息。
如果它类似于连接问题,您可能需要引入重试机制,不确定您的脚本是否可能从多个位置并行执行,但如果是的话,您应该查看http://php.net/manual/en/function.uniqid.php作为一种方法,首先生成一个相当独特的文件名,然后尝试下载,然后只在没有返回错误的情况下将文件移动到预定的目标文件,否则,请重试到X次。
关于Curl的稳定性,我经常使用它,而且它对我来说并不是不稳定的,但是我不会删除二进制数据。我希望错误信息的一些错误检测和输出能够更清楚地说明问题的根本原因。
https://stackoverflow.com/questions/14955266
复制相似问题