Skip to content
HDsky's Blog
Go back

在服务器中屏蔽非中国地区的IP访问

如果服务器面向的用户主要是国内用户,如何拒绝国外IP/屏蔽国外IP访问服务器?

保存下面的脚本为 allcn.sh

#!/bin/bash

mmode=$1

#wget https://ghfast.top/https://github.com/17mon/china_ip_list/blob/master/china_ip_list.txt

CNIP="/home/username/china_ip_list.txt"

gen_iplist() {
    cat <<-EOF
        $(cat ${CNIP:=/dev/null} 2>/dev/null)
EOF
}

flush_r() {
    iptables -F ALLCNRULE 2>/dev/null
    iptables -D INPUT -p tcp -j ALLCNRULE 2>/dev/null
    iptables -X ALLCNRULE 2>/dev/null
    ipset -X allcn 2>/dev/null
}

mstart() {
    ipset create allcn hash:net 2>/dev/null
    ipset -! -R <<-EOF
$(gen_iplist | sed -e "s/^/add allcn /")
EOF

    iptables -N ALLCNRULE
    iptables -I INPUT -p tcp -j ALLCNRULE

    # 1. 放行已建立和关联的连接
    iptables -A ALLCNRULE -m conntrack --ctstate ESTABLISHED,RELATED -j RETURN

    # 2. 本地及内网地址放行
    iptables -A ALLCNRULE -s 127.0.0.0/8 -j RETURN
    iptables -A ALLCNRULE -s 169.254.0.0/16 -j RETURN
    iptables -A ALLCNRULE -s 224.0.0.0/4 -j RETURN
    iptables -A ALLCNRULE -s 255.255.255.255 -j RETURN

    iptables -A ALLCNRULE -s 10.0.0.0/8 -j RETURN
    iptables -A ALLCNRULE -s 172.16.0.0/12 -j RETURN
    iptables -A ALLCNRULE -s 192.168.0.0/16 -j RETURN

    # 3. 来自中国大陆 IP 放行
    iptables -A ALLCNRULE -m set --match-set allcn src -j RETURN

    # 4. 其余 DROP
    iptables -A ALLCNRULE -p tcp -j DROP
}

# 主入口逻辑
if [ "$mmode" == "stop" ]; then
    flush_r
    exit 0
fi

flush_r
sleep 1
mstart

屏蔽国外IP。

./allcn.sh

解除屏蔽国外IP。

./allcn.sh stop

查看iptables,检查屏蔽或解除屏蔽的结果。

iptables -L

Share this post:

Next Post
如何卸载Dify