WireShark使用过程中,最常见的操作莫过于设置过滤器了.当然你可以通过Filter Express点击鼠标来选择过滤器表达式,也可以更快捷的在Express编辑框中直接输入来进行配置。

0×01 常见表达式运算符

给一张图吧,比较直观.


is present :存在

==、!=、<、>、<=、>= :等于,不等…类推,==也用eq代替

contains :包含

matches :匹配

and,or,not :&& || ! 逻辑语,逻辑或,逻辑非

0×02 表达式构成

一般是的结构是 Protocal.Properties == XXX

也可以使用语法判断,在编写过滤脚本时能用到.

0×03 常规应用实例

1.针对IP过滤的例子

抓取满足源地址的包: ip.src == 192.168.0.1

抓取满足目标地址的包: ip.dst == 192.168.0.1

抓取满足源地址或目标地址的包: ip.addr == 192.168.0.1,或者 ip.src == 192.168.0.1 or ip.dst == 192.168.0.1

2.针对Port过滤的例子

捕获单一端口: tcp.port == 80

捕获范围端口: udp.port >= 2048 and upd.port <= 65000

3.针对Protocal过滤的例子

捕获单一协议: http

捕获多种协议: http or telnet

4.针对包长度和内容过滤的例子

捕获特定长度的包: http.content_length <=100

捕获特定内容的包: http.request.uri matches “blackh4t”

5.高级过滤的使用

每个都可以加入逻辑运算符组成高级表达式

如:

(src host 10.4.1.12 or src net 10.6.0.0/16) and tcp dst portrange 200-10000 and dst net 10.0.0.0/8

!(arp.src==192.168.1.1) and !(arp.dst.proto_ipv4==192.168.1.243)

当遇到具体协议的具体属性不明晰时可以查看手册,但一般都是英文简略缩写,所以很好理解.

0×04 表达式语法附录

主要是整理了一些协议或者表达式格式的常见用法

[src|dst] host <host> 尖括号里的是一个主机IP或主机名字,用src、dst来设定这是目的地址或源地址。 这个选项能过滤主机IP和名字

ether [src|dst] host <ehost> 尖括号里的是一个网络地址,用src、dst来设定这是目的地址或源地址。

gateway host <host> <host> 是一个网关,抓取流过 <host> 的数据包,但这些数据包的目的地址和源地址都不是 <host>。

[src|dst] net <net> [{mask <mask>}|{len <len>}] <net>表示一个网络地址,可以用 src、dst来表示这个网络是目的地址还是源地址的数据包。如果没有”src/dst”,表示全部数据包。可以选择加上子网掩码或使用无类型域间选路(CIDR)的方式。

[tcp|udp] [src|dst] port <port> [tcp|udp]是选择抓取的协议类型,<port>指定端口。需要注意的是,[tcp|udp]必需在[src|dst]之前。

less|greater <length> 抓取碎片数据包或指定长度的数据包。less 与 greater 分别对应小包与大包。

ip|ether proto <protocol> 在数据链路层上,在指定的IP地址或网络地址(ip|ether)上抓取指定协议<protocol>的数据包。

ether|ip broadcast|multicast 在指定的网络地址或IP地址上抓取广播包或组播包。

0×05 补充

Ettercap的过滤脚本语法基本都大同小异,除此之外常见的全功能多协议的嗅探工具还有OmniPeek,老牌的Sniffer Pro等等..另外推一个小工具,因为对于特定进程的包捕获,我也没找到特别好的语法,一般是结合Netstat之类的命令找出对应进程的PID和端口再进行过滤器配置,而Appsniffer这个小工具很好的解决了这个问题,其需要.net的支持.

未尽错误之处还望各位指正. hv fun ;)

源链接

Hacking more

...