防止fsockopen phpddos处理方案

作者: 蓝鹰 分类: WEB环境 发布时间: 2013-10-15 14:36 ė135 浏览数 6防止fsockopen phpddos处理方案已关闭评论

由于PHP新的BUG被大规模利用,很多客户机器都被植入了PHP-DDoS攻击脚本,访问触发后会进行攻击他人服务器的行为。特征:用PHP代码调用sockets,直接用服务器的网络攻击别的IP。

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

$fp = fsockopen(“udp://$host”, $port, $errno, $errstr, 5);

if($fp){

fwrite($fp, $out);

fclose($fp);

php脚本中的 fsockopen 函数,对外部地址,通过UDP发送大量的数据包,攻击对方。

解决方案:

可通过 php.ini ,禁用 fsockopen 函数,及使用Windows 2003的 安全策略屏蔽本机的UDP端口,Linux主机则通过配置iptable

一、禁用fsockopen函数

在php.ini里禁用如下函数:

disable_functions =gzinflate,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

在php.ini里禁用fopen

allow_url_fopen = Off

并且注释掉sockets:

;extension=php_sockets.dll

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

然后重启IIS或者apache。

二、关闭UDP端口

1、windows系统:

1.在IP策略,或防火墙中,禁止所有udp向外发送

将以下文本复制到记事本,另存为 banudp.bat 或任意名,双击运行即可,

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=any description=dns访问 protocol=udp mirrored=yes dstport=53

REM 添加筛选器到IP筛选器列表(不让别人访问)

netsh ipsec static add filter filterlist=拒绝列表 srcaddr=any dstaddr=me 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

2、Linux系统:

iptables -A INPUT -p udp –sport 5000:65535 -j DROP

三、快速找出被插入php-ddos木马的网站

1、windows系统

打开网站的日志文件,搜索包含port=的记录

2、Linux系统

# less /var/log/httpd/access_log |grep host=

执行该命令后,你可以看到类型如下的信息:

xxx.xxx 222.186.37.71 – – [20/Dec/2011:00:37:04 +0800] “GET /plus/postoctar.php?host=119.147.145.159&port=17001&time=69 HTTP/1.1″ 200 9990972 “-” “Mozilla/4.0″

本文出自 蓝鹰博客,转载时请注明出处及相应链接。

本文永久链接: http://www.lanyingblog.com/blog/862.html

Ɣ回顶部