在您的帮助之后,许多stackoverflow帖子,解决方案在此帖子的底部作为更新。
我正在尝试使用此代码在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);
}
}
第一个问题:
$num1
和$num2
应该从000到999开始,而不是从0到999.放置更多$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
}
}
}
答案 0 :(得分:2)
当你处理整数时,你不能说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,这是值得的,他们的免费帐户就足够了您。