黑帽联盟

 找回密码
 会员注册
查看: 587|回复: 0
打印 上一主题 下一主题

[资源教程] 使用ipset设置防火墙端口白名单,只让指定国家访问

[复制链接]

895

主题

38

听众

3322

积分

管理员

Rank: 9Rank: 9Rank: 9

  • TA的每日心情

    前天 13:01
  • 签到天数: 1643 天

    [LV.Master]伴坛终老

    说明:很早前发过VPS一键屏蔽指定国家IP的教程,查看:Linux VPS一键屏蔽指定国家所有的IP访问,这对于我们阻止某个国家访问网站和CC攻击还是很有用的,不过鉴于很多人需要白名单设置方法,博主研究了下,发现也可以用ipset来完成,这里就说下,目前测试是没问题的。

    方法
    首先需要得到国家IP段,下载地址:http://www.ipdeny.com/ipblocks/。这里以我们国家为例。

    1、安装ipset
    #Debian/Ubuntu系统
    apt-get -y install ipset

    #CentOS系统
    yum -y install ipset

    CentOS 7还需要关闭firewall防火墙:
    systemctl stop firewalld.service
    systemctl disable firewalld.service

    2、清空之前的规则
    #防止设置不生效,建议清空下之前的防火墙规则
    iptables -P INPUT ACCEPT
    iptables -F

    3、创建新规则
    #创建一个名为cnip的规则
    ipset -N cnip hash:net

    #下载国家IP段,这里以中国为例
    wget -P . http://www.ipdeny.com/ipblocks/data/countries/cn.zone

    #将IP段添加到cnip规则中
    for i in $(cat /root/cn.zone ); do ipset -A cnip $i; done

    4、设置IP段白名单
    #放行IP段
    iptables -A INPUT -p tcp -m set --match-set cnip src -j ACCEPT

    #关掉所有端口
    iptables -P INPUT DROP

    这时候就只有指定国家的IP能访问服务器了。

    如果你在国内,网站不允许被国内人访问,建议别关所有端口,这样你的SSH会上不去,我们可以只关闭80/443端口。
    #关闭指定端口,比如80/443
    iptables -A INPUT -p tcp --dport 80 -j DROP
    iptables -A INPUT -p tcp --dport 443 -j DROP

    这时候其他国家的IP是无法访问你服务器的80/443端口,等于无法访问你的网站,其它端口还是可以访问的。

    5、删除规则
    #将参数里的-A改成-D就是删除规则了,如
    iptables -D INPUT -p tcp -m set --match-set cnip src -j ACCEPT
    iptables -D INPUT -p tcp --dport 443 -j DROP

    说明
    设置防火墙后,可能有些服务器重启系统后会清空防火墙规则,导致设置的失效,所以我们设置规则后,需要使用iptables命令保存下,保存命令可能在很多系统中都不通用,这里就不说了,需要各位自行搜索解决了,有耐心的也可以每次重启的时候都重新设置一下防火墙。

    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    勿忘初心,方得始终!
    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部