欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

IIS环境中防止本地用户用fsockopen进行DDOS攻击的方法

程序员文章站 2022-03-05 16:44:21
...
  1. /*
  2. from: http://bbs.it-home.org
  3. date: 2013/2/17
  4. */
  5. $fp = fsockopen("udp://$ip", $rand, $errno, $errstr, 5);
  6. if($fp){
  7. fwrite($fp, $out);
  8. fclose($fp);
  9. ?>
复制代码

针对这种情况,可以修改 php.ini ,禁用 fsockopen 函数,及使用Windows 2003的 安全策略 屏蔽本机的UDP端口。

1)、禁用函数 查找到 disable_functions ,添加需禁用的函数名,如下例:

  1. passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,pfsockopen,openlog,
  2. syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket,fsockopen
复制代码

重启IIS后生效。

2)、屏蔽UDP端口 复制到记事本,另存为任意名称的bat文件,双击运行即可。

  1. REM 添加安全策略,名称

  2. netsh ipsec static add policy name=我的安全策略
  3. REM 添加 IP筛选器列表

  4. netsh ipsec static add filterlist name=允许列表
  5. netsh ipsec static add filterlist name=拒绝列表
  6. REM 添加筛选器到IP筛选器列表(允许上网)

  7. netsh ipsec static add filter filterlist=允许列表 srcaddr=me dstaddr=any description=dns访问 protocol=udp mirrored=yes dstport=53
  8. REM 添加筛选器到IP筛选器列表(不让别人访问)

  9. netsh ipsec static add filter filterlist=拒绝列表 srcaddr=any dstaddr=me description=别人到我任何访问 protocol=udp mirrored=yes
  10. REM 添加筛选器操作

  11. netsh ipsec static add filteraction name=可以 action=permit
  12. netsh ipsec static add filteraction name=不可以 action=block
  13. @REM http://bbs.it-home.org

  14. REM 创建一个链接指定 IPSec 策略、筛选器列表和筛选器操作的规则(加入规则到我的安全策略)
  15. netsh ipsec static add rule name=允许规则 policy=我的安全策略 filterlist=允许列表 filteraction=可以
  16. netsh ipsec static add rule name=拒绝规则 policy=我的安全策略 filterlist=拒绝列表 filteraction=不可以
  17. REM 激活我的安全策略

  18. netsh ipsec static set policy name=我的安全策略 assign=y
复制代码