zoukankan      html  css  js  c++  java
  • iptables [match] 常用封包匹配参数

    参数 -p, --protocol
    范例 iptables -A INPUT -p tcp
    说明 匹配通讯协议类型是否相符,可以使用 ! 运算符进行反向匹配,例如:
    -p !tcp
    意思是指除 tcp 以外的其它类型,如udp、icmp ...等。
    如果要匹配所有类型,则可以使用 all 关键词,例如:
    -p all

    参数 -s, --src, --source
    范例 iptables -A INPUT -s 192.168.1.1
    说明 用来匹配封包的来源 IP,可以匹配单机或网络,匹配网络时请用数字来表示 子网掩码,例如:
    -s 192.168.0.0/24
    匹配 IP 时可以使用 ! 运算符进行反向匹配,例如:
    -s !192.168.0.0/24。

    参数 -d, --dst, --destination
    范例 iptables -A INPUT -d 192.168.1.1
    说明 用来匹配封包的目的地 IP,设定方式同上。

    参数 -i, --in-interface
    范例 iptables -A INPUT -i eth0
    说明 用来匹配封包是从哪块网卡进入,可以使用通配字符 + 来做大范围匹配,例如:
    -i eth+
    表示所有的 ethernet 网卡
    也可以使用 ! 运算符进行反向匹配,例如:
    -i !eth0

    参数 -o, --out-interface
    范例 iptables -A FORWARD -o eth0
    说明 用来匹配封包要从哪 块网卡送出,设定方式同上。

    参数 --sport, --source-port
    范例 iptables -A INPUT -p tcp --sport 22
    说明 用来匹配封包的源端口,可以匹配单一端口,或是一个范围,例如:
    --sport 22:80
    表示从 22 到 80 端口之间都算是符合条件,如果要匹配不连续的多个端口,则必须使用 --multiport 参数,详见后文。匹配端口号时,可以使用 ! 运算符进行反向匹配。

    参数 --dport, --destination-port
    范例 iptables -A INPUT -p tcp --dport 22
    说明 用来匹配封包的目的地端口号,设定方式同上

    参数 --tcp-flags
    范例 iptables -p tcp --tcp-flags SYN,FIN,ACK SYN
    说明匹配 TCP 封包的状态标志,参数分为两个部分,第一个部分列举出想 匹配的标志,第二部分则列举前述标志中哪些有被设置,未被列举的标志必须是空的。TCP 状态标志包括:SYN(同步)、ACK(应答)、FIN(结束)、RST(重设)、URG(紧急) 、PSH(强迫推送) 等均可使用于参数中,除此之外还可以使用关键词 ALL 和 NONE 进行匹配。匹配标志时,可以使用 ! 运算符行反向匹配。

    参数 --syn
    范例 iptables -p tcp --syn
    说明 用来表示TCP通信协议中,SYN位被打开,而ACK与FIN位关闭的分组,即TCP的初始连接,与 iptables -p tcp --tcp-flags SYN,FIN,ACK SYN 的作用完全相同,如果使用 !运算符,可用来 匹配非要求连接封包。

    参数 -m multiport --source-port
    范例 iptables -A INPUT -p tcp -m multiport --source-port 22,53,80,110
    说明用来匹配不连续的多个源端口,一次最多可以匹配 15 个端口,可以使用 ! 运算符进行反向匹配。

    参数 -m multiport --destination-port
    范例 iptables -A INPUT -p tcp -m multiport --destination-port 22,53,80,110
    说明用来 匹配不连续的多个目的地端口号,设定方式同上

    参数 -m multiport --port
    范例 iptables -A INPUT -p tcp -m multiport --port 22,53,80,110
    说明 这个参数比较特殊,用来匹配源端口和目的端口号相同的封包,设定方式同上。注意:在本范例中,如果来源端口号为 80目的地端口号为 110,这种封包并不算符合条件。

    参数 --icmp-type
    范例 iptables -A INPUT -p icmp --icmp-type 8
    说明用来匹配 ICMP 的类型编号,可以使用代码或数字编号来进行 匹配。请打 iptables -p icmp --help 来查看有哪些代码可用。

    参数 -m limit --limit
    范例 iptables -A INPUT -m limit --limit 3/hour
    说明 用来匹配某段时间内封包的平均流量,上面的例子是用来 匹配:每小时平均流量是否超过一次 3 个封包。 除了每小时平均次外,也可以每秒钟、每分钟或每天平均一次,默认值为每小时平均一次,参数如后: /second、 /minute、/day。 除了进行封 包数量的匹配外,设定这个参数也会在条件达成时,暂停封包的匹配动作,以避免因骇客使用洪水攻击法,导致服务被阻断。

    参数 --limit-burst
    范例 iptables -A INPUT -m limit --limit-burst 5
    说明 用来匹配瞬间大量封包的数量,上面的例子是用来匹配一次同时涌入的封包是否超过 5 个(这是默认值),超过此上限的封包将被直接丢弃。使用效果同上。

    参数 -m mac --mac-source
    范例 iptables -A INPUT -m mac --mac-source 00:00:00:00:00:01
    说明 用来匹配封包来源网络接口的硬件地址,这个参数不能用在 OUTPUT 和 POSTROUTING 规则链上,这是因为封包要送到网 卡后,才能由网卡驱动程序透过 ARP 通讯协议查出目的地的 MAC 地址,所以 iptables 在进行封包匹配时,并不知道封包会送到哪个网络接口去。

    参数 --mark
    范例 iptables -t mangle -A INPUT -m mark --mark 1
    说明 用来匹配封包是否被表示某个号码,当封包被 匹配成功时,我们可以透过 MARK 处理动作,将该封包标示一个号码,号码最大不可以超过 4294967296。

    参数 -m owner --uid-owner
    范例
    iptables -A OUTPUT -m owner --uid-owner 500
    说明 用来匹配来自本机的封包,是否为某特定使用者所产生的,这样可以避免服务器使用 root 或其它身分将敏感数据传送出,可以降低系统被骇的损失。可惜这个功能无法 匹配出来自其它主机的封包。

    参数 -m owner --gid-owner
    范例 iptables -A OUTPUT -m owner --gid-owner 0
    说明 用来匹配来自本机的封包,是否为某特定使用者群组所产生的,使用时机同上。

    参数 -m owner --pid-owner
    范例
    iptables -A OUTPUT -m owner --pid-owner 78
    说明 用来匹配来自本机的封包,是否为某特定进程所产生的,使用时机同上。

    参数 -m owner --sid-owner
    范例
    iptables -A OUTPUT -m owner --sid-owner 100
    说明 用来匹配来自本机的封包,是否为某特定 连接(Session ID)的响应封包,使用时机同上。

    参数 -m state --state
    范例
    iptables -A INPUT -m state --state RELATED,ESTABLISHED
    说明 用来匹配连接状态, 连接状态共有四种:INVALID、ESTABLISHED、NEW 和 RELATED。
    INVALID 表示该封包的连接编号(Session ID)无法辨识或编号不正确。
    ESTABLISHED 表示该封包属于某个已经建立的连接。
    NEW 表示该封包想要起始一个连接(重设连接或将连接重导向)。
    RELATED 表示该封包是属于某个已经建立的连接,所建立的新连接。例如:FTP-DATA 连接必定是源自某个 FTP 连接。

  • 相关阅读:
    JAVA基础:JAVA代码编写的30条建议
    Oracle学习之三 程序控制结构
    ExtJs 常用代码片段(7.30更新)
    ExtJs4 之数据模型
    .NET 大杂烩
    .NET 导出Excel
    Javascript实现IE直接打印
    C# Timer用法及实例
    AjaxPro实现无刷新多级联动实例
    VB6.0输入文本写进UTF8格式的文本文件
  • 原文地址:https://www.cnblogs.com/fanweisheng/p/11130208.html
Copyright © 2011-2022 走看看