在您的帮助下,许多stackoverflow帖子都发布了解决方案,该解决方案在本文的底部显示为UPDATE
我正在尝试使用以下代码在php文件中自动保存一些图像:
for ($num1=100;$num1<999;$num1++)
{
for ($num2=100;$num2<999;$num2++)
{
$postURL = "http://link_00000'.$num1.'_'.$num2.'.jpg";
$ch = curl_init('http://link_00000'.$num1.'_'.$num2.'.jpg');
$fp = fopen($postURL, '/path/Apolo/img/'.$num1.'_'.$num2.'.jpg', 'wb');
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_exec($ch);
curl_close($ch);
fclose($fp);
}
}
第一个问题:
CCD_ 1和CCD_。添加更多的$num
变量($num3
、$num4
…)将是一个解决方案,但我认为数字有更好的解决方案。
第二个问题:
图像不会保存。我也试过这个,但没有用:
copy($postURL, '/path/img/'.$num1.'_'.$num2.'.jpg');
第三个问题:
如何防止类似d-dos攻击的操作?如果我加载链接没有时间延迟,网站可能会关闭。
UPD:
for ($num1=000;$num1<999;$num1++)
{
for ($num2=000;$num2<999;$num2++)
{
$url = 'http://link.com/00000'.sprintf("%03d", $num1).'_'.sprintf("%03d", $num2).'.jpg';
echo ''.$num1.'_'.$num2.'';
echo "n";
if (@getimagesize($url)) \ checks if url-image exists
{
echo $url;
$ch = curl_init($url);
$fp = fopen('/path/Apolo/00000'.sprintf("%03d", $num1).'_'.sprintf("%03d", $num2).'.jpg', 'wb');
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_exec($ch);
curl_close($ch);
fclose($fp);
sleep(1); //1 second delay to avoid d-dos
}
}
}
当你处理整数时,你不能说000,因为它等于0,如果你想让它写000,那么你应该使用字符串
在你的例子中,你正在循环数字,所以如果你不想循环,把它写成字符串会很麻烦。
因此,最好的解决方案是自己添加前导0,可以这样做:sprintf("%03d", $num1);
这将自动添加您想要的前导零。
更新1:(忘记回答保存图像)
为了保存图像,您可以这样做:file_put_contents('/path/Apolo/img/filename'.sprintf("%03d", $num1).'_'.sprintf("%03d", $num2).'.jpg', file_get_contents($postURL));
更新2:(代码示例):
for ($num1=100;$num1<999;$num1++)
for ($num2=100;$num2<999;$num2++){
$postURL = 'http://link_00000'.sprintf("%03d", $num1).'_'.sprintf("%03d", $num2).'.jpg';
$path = '/path/Apolo/img/filename'.sprintf("%03d", $num1).'_'.sprintf("%03d", $num2).'.jpg';
file_put_contents($path, file_get_contents($postURL));
}
问题3:
有很多方法可以防止DDOS攻击,但如果你只是想让你的网站快速运行并防止/处理DDOS攻击然后将你的DNS更改为cloudflare,这是值得的,他们的免费帐户对你来说已经足够了