所以我一直遇到同样的错误...我已经搜索了几个小时试图找到一个分辨率,但我似乎无法找到丢失的部分。很多其他人在堆栈溢出时询问错误7,但没有一个与我的场景类似。
基本上,我使用cURL下载通过XML Feed发送的图像。我的整个脚本都可以运行,一切运行,我在下面写的功能甚至可以下载数千张图像(有时会上升到3000个范围)。
我想我的问题是,为什么在下载3000张图片之后才会连接?
function downloadImage($location, $imagesPath, $imageName) {
//Location fix
$location = str_replace(" ", "%20", $location);
$url = $location;
$path = $imagesPath . $imageName;
$fp = fopen($path, 'w');
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_FRESH_CONNECT, true);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 0); //Wait indefinitately
curl_setopt($ch, CURLOPT_DNS_USE_GLOBAL_CACHE, false);
$data = curl_exec($ch);
if ($data === false) {
echo "DownloadImage cURL failed 1: (" . curl_errno($ch) . ") " . curl_error($ch) . "<br/>";
//exit;
}
curl_close($ch);
fclose($fp);
}
答案 0 :(得分:1)
所以为了让这个工作起作用,我不得不在这个功能上设置一个瓶颈来减慢它的速度。正如安德鲁斯建议的那样,远程站点让我过快地下载图像。为了阻止这个功能,我将每个图像FTP到远程服务器(因为这是必需的)。
最终功能如下:
function downloadImage($location, $imagesPath, $imageName, $ch3, $feedFTPinfo) {
//Location fix
//$location = str_replace(" ", "%20", $location);
$url = $location;
$path = $imagesPath . $imageName;
$fp = fopen($path, 'w');
$ch2 = curl_init(); // Initiate cURL for downloading images
//Setup the cURL options for the second handle ($ch2)
curl_setopt($ch2, CURLOPT_URL, $url);
curl_setopt($ch2, CURLOPT_FILE, $fp);
curl_setopt($ch2, CURLOPT_CONNECTTIMEOUT, 0); //Wait indefinitately
curl_setopt($ch2, CURLOPT_FOLLOWLOCATION, true);
//Execute the cURL session
$data2 = curl_exec($ch2);
//Resize Images
$image = new SimpleImage();
$image->load($url);
$imageNameSm = str_replace(".jpg", "", $imageName);
$imageNameSm = $imageNameSm."_sm2.jpg";
$image->resizeToWidth(120);
$image->save($imagesPath . $imageNameSm);
$smPath = $imagesPath . $imageNameSm;
//Find out if there were any issues
if ($data2 === false) {
echo "DownloadImage cURL failed 1: (" . curl_errno($ch2) . ") " . curl_error($ch2) . "<br/>";
//exit;
} else {
//There weren't any issues downloading the file, move it to the speficifed ftp server
if (!empty($feedFTPinfo)) {
$localfile = $path;
$fp = fopen($localfile, 'r');
//Setup the options for the 3rd handle
curl_setopt($ch3, CURLOPT_URL, $feedFTPinfo.$imageName);
curl_setopt($ch3, CURLOPT_CONNECTTIMEOUT, 0); //Wait indefinitately
curl_setopt($ch3, CURLOPT_UPLOAD, 1);
curl_setopt($ch3, CURLOPT_INFILE, $fp);
curl_setopt($ch3, CURLOPT_INFILESIZE, filesize($localfile));
//Execute the 3rd cURL handle
$data3 = curl_exec($ch3);
//Find out if there were any issues with the execution
if ($data3 === false) {
echo "Uploading the image via FTP failed: (" . curl_errno($ch3) . ") " . curl_error($ch3) . "<br/>";
//exit;
}
$localfile = $smPath;
$fp = fopen($localfile, 'r');
//Setup the options for the 3rd handle
curl_setopt($ch3, CURLOPT_URL, $feedFTPinfo.$imageNameSm);
curl_setopt($ch3, CURLOPT_CONNECTTIMEOUT, 0); //Wait indefinitately
curl_setopt($ch3, CURLOPT_UPLOAD, 1);
curl_setopt($ch3, CURLOPT_INFILE, $fp);
curl_setopt($ch3, CURLOPT_INFILESIZE, filesize($localfile));
//Execute the 3rd cURL handle
$data3 = curl_exec($ch3);
//Find out if there were any issues with the execution
if ($data3 === false) {
echo "Uploading the small image via FTP failed: (" . curl_errno($ch3) . ") " . curl_error($ch3) . "<br/>";
//exit;
}
}
}
curl_close($ch2); //Close the cURL handle that downloads images
fclose($fp);
}
如果您不需要在某个地方使用ftp来创建瓶颈,可以在sleep
函数中使用php的usleep
(秒)或downloadImage
(微秒)函数来创建类似的瓶颈。
sleep
文档:
http://php.net/manual/en/function.sleep.php usleep
文档:
http://php.net/manual/en/function.usleep.php 希望这个理论可以帮助其他人。