使用变量

时间:2015-12-04 09:57:41

标签: php digit ddos save-image

在您的帮助之后,许多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
        }
    }
}

1 个答案:

答案 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,这是值得的,他们的免费帐户就足够了您。