Blog

防范PHP-DDoS攻击脚本解决方法

   由于新的PHP程序bug被发现,引起WEB服务器可被利用而发出UDP封包DDOS,特别是使用dedecms的童鞋受害更严重,经常听到有使用dedecms的被注入木马进行php发包,再加上织梦漏洞之王的名称,所以现在很多主机商都拒绝dedecms程序了

PHP脚本DDOS攻击的原因及php脚本部分源码:

        $fp = fsockopen(“udp://$ip”, $rand, $errno, $errstr, 5);
        if($fp){
                fwrite($fp, $out);
                fclose($fp);
php脚本中的 fsockopen 函数,对外部地址,通过UDP发送大量的数据包,攻击对方。

解决方案:可通过 php.ini ,禁用 fsockopen 函数,及使用Windows 2003的 安全策略 屏蔽本机的UDP端口。
1、禁用 fsockopen 函数 。
查找到 disable_functions ,添加需禁用的函数名,如下:

passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,pfsockopen,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket,fsockopen
重启IIS后即可生效。

2、屏蔽UDP端口。
将以下着色文本复制到记事本,另存为 antiudp.bat 或其他名字,双击运行即可封锁掉本地UDP端口。
REM 添加安全策略,名称
netsh ipsec static add policy name=我的安全策略
REM 添加 IP筛选器列表
netsh ipsec static add filterlist name=允许列表
netsh ipsec static add filterlist name=拒绝列表
REM 添加筛选器到IP筛选器列表(允许上网)
netsh ipsec static add filter filterlist=允许列表  srcaddr=me dstaddr=8.8.8.8 description=dns访问 protocol=udp mirrored=yes dstport=53
REM 添加筛选器到IP筛选器列表(不让别人访问)
netsh ipsec static add filter filterlist=拒绝列表 srcaddr=me dstaddr=any description=别人到我任何访问 protocol=udp mirrored=yes
REM 添加筛选器操作
netsh ipsec static add filteraction name=可以  action=permit
netsh ipsec static add filteraction name=不可以  action=block
REM 创建一个链接指定 IPSec 策略、筛选器列表和筛选器操作的规则(加入规则到我的安全策略)
netsh ipsec static add rule name=允许规则  policy=我的安全策略 filterlist=允许列表 filteraction=可以
netsh ipsec static add rule name=拒绝规则  policy=我的安全策略 filterlist=拒绝列表 filteraction=不可以
REM 激活我的安全策略
netsh ipsec static set policy name=我的安全策略 assign=y

注:上文中 “dstaddr=8.8.8.8” 其中的IP修改为正在使用的DNS服务器IP。

Linux下利用iptables来屏蔽UDP端口为:
iptables -A INPUT -p tcp -m tcp –sport 53 –dport 1024:65535 -m state –state ESTABLISHED -j ACCEPT
iptables -A INPUT -p udp -m udp –sport 53 –dport 1024:65535 -m state –state ESTABLISHED -j ACCEPT
iptables -A OUTPUT -p tcp -m tcp –sport 1024:65535 -d 8.8.8.8 –dport 53 -m state –state NEW,ESTABLISHED -j ACCEPT
iptables -A OUTPUT -p udp -m udp –sport 1024:65535 -d 8.8.8.8 –dport 53 -m state –state NEW,ESTABLISHED -j ACCEPT -A OUTPUT -p udp -j REJECT
注:上文中 8.8.8.8为当前正常使用的DNS服务器IP。

没有评论

Leave a Reply