防止本地用户用fsockopen DDOS攻击对策

2015-01-24信息快讯网

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

原因
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端口。

禁用函数
查找到 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后生效。

屏蔽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
基于Zookeeper的使用详解
关于shopex同步ucenter的redirect问题,导致script不运行
phpExcel导出大量数据出现内存溢出错误的解决方法
php判断上传的Excel文件中是否有图片及PHPExcel库认识
PHPEXCEL 使用小记
PHP flock 文件锁详细介绍
PHP fopen 读取带中文URL地址的一点见解
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别
php中jQuery插件autocomplate的简单使用笔记
openflashchart 2.0 简单案例php版
simplehtmldom Doc api帮助文档
Notice: Trying to get property of non-object problem(PHP)解决办法
用phpmailer实现简单openvpn用户认证的实现代码
PHP异步调用socket实现代码
php fsockopen中多线程问题的解决办法[翻译]
php空间不支持socket但支持curl时recaptcha的用法
php获取远程图片的两种 CURL方式和sockets方式获取远程图片
PHP安全防范技巧分享
PHP隐形一句话后门,和ThinkPHP框架加密码程序(base64_decode)
让Json更懂中文(JSON_UNESCAPED_UNICODE)
PHP下利用shell后台运行PHP脚本,并获取该脚本的Process ID的代码
利用Ffmpeg获得flv视频缩略图和视频时间的代码
php中使用Curl、socket、file_get_contents三种方法POST提交数据
不支持fsockopen但支持culr环境下下ucenter与modoer通讯问题
shopex中集成的站长统计功能的代码简单分析
ThinkPHP与PHPExcel冲突解决方法
php模拟socket一次连接,多次发送数据的实现代码
PHP读取网页文件内容的实现代码(fopen,curl等)
不重新编译PHP为php增加openssl模块的方法
php错误提示failed to open stream: HTTP request failed!的完美解决方法
PHP数组的交集array_intersect(),array_intersect_assoc(),array_inter_key()函数的小问题
php HandlerSocket的使用
©2014-2024 dbsqp.com