美文网首页
Linux利用iptables屏蔽某些域名

Linux利用iptables屏蔽某些域名

作者: y2015 | 来源:发表于2019-05-10 10:04 被阅读0次

    一般 iptables 自带的都有 string 模块,这个模块的作用就是匹配字符串,匹配到泛域名的URL,然后就把数据包丢弃,就实现了屏蔽泛域名的功能。比如可以限制SS访问youtube.com

     以下规则是屏蔽以 youtube.com 为主的所有一级 二级 三级等域名。
    
    iptables -A OUTPUT -m string --string "youtube.com" --algo bm --to 65535 -j DROP
     # 添加屏蔽规则
    
    iptables -D OUTPUT -m string --string "youtube.com" --algo bm --to 65535 -j DROP
     # 删除屏蔽规则,上面添加的代码是什么样,那么删除的代码就是把 -A 改成 -D
    

    解释:

    -A
     # 添加iptables规则;
     -D
     # 删除iptables规则(把添加防火墙规则时代码中的 -A 改成 -D 即可删除添加的规则);
     -m string
     # 指定模块;
     --string "youtube.com"
     # 指定要匹配的字符串(域名、关键词等);
     --algo bm
     # 指定匹配字符串模式/算法(还有一种更复杂的算法:kmp);
     --to 65535
     # 指定端口,这里代表所有端口(1-65535);
     -j DROP
     # 指匹配到数据包后处理方式,这里是丢弃数据包。
    

    这个模块的作用就是匹配字符串,这个字符串可以是URL、普通文本、文件后缀(后两者时,如果目标网站启用了GZIP类压缩算法,就会无法过滤匹配,毕竟都压缩了)

    比如: .zip ,就会把包含 .zip 的数据库丢弃,这样就会无法下载 .zip 类型的文件了!

    其他的作用大家可以慢慢研究。

    此文转载自https://doub.io/wlzy-25/

    相关文章

      网友评论

          本文标题:Linux利用iptables屏蔽某些域名

          本文链接:https://www.haomeiwen.com/subject/fnjooqtx.html