曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 4474|回复: 0
打印 上一主题 下一主题

[iptables] 字符串匹配过滤(mangle 表的使用)

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2015-5-30 23:20:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
要使用基于字符串匹配的过滤,应该先安装相应的软件包 iptables-mod-filter :
opkg update
opkg install iptables-mod-filter
reboot

所需依赖会自动被装上。

或者在编译时将其选中,它还有一个依赖 kmod-ipt-filter ,这个也要选中。

一般情况下,比如想过滤掉 qq.com 这个域名的访问,那么可以如下使用:
iptables -A FORWARD -m string --algo bm --string "qq.com" -j DROP

其中 --algo 后接算法,算法有两个, bm 或 kmp 可选。

不过我的测试结果是,在 BB 14.07 下,使用 FORWARD 链,无论是 -A 还是 -I 插入,都没办法使规则生效,但是使用 mangle 表就可以,如:
iptables -t mangle -I PREROUTING -p tcp -m string --algo bm --string "qq.com" --icase -j DROP

其中,--icase 是忽略字串的大小写。

顺便说一下,如果你用过 dnsmasq 来过滤一些域名的话,可能会遇到想过滤的栏目并不是以一个二级域名呈现,而是在某个目录下,比如:

这时,就可以通过这种字符串过滤的方法来解决,比如:
iptables -t mangle -I PREROUTING -p tcp -m string --algo bm --string "bbs/list_" --icase -j DROP

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2024-5-2 03:26 , Processed in 0.076520 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表