libpcap 过滤 pcap_compile

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了libpcap 过滤 pcap_compile相关的知识,希望对你有一定的参考价值。

libpcap 是使用 lex 和 yacc 生成 scanner.c 等文件,用以过滤的规则生成的。

/* make 中的 lex、yacc 部分步骤 */
./runlex.sh lex -oscanner.c scanner.l
mv scanner.c scanner.c.bottom
cat ./scanner.c.top scanner.c.bottom > scanner.c
yacc -d grammar.y
yacc: 38 shift/reduce conflicts.
mv y.tab.c grammar.c
mv y.tab.h tokdefs.h

pcap_compile 函数主要调用层次

pcap_compile()
{
  lex_init(buf1) {
    yy_scan_string(buf2) {
      yy_scan_bytes(buf3) {
        yy_switch_to_buffer(buf4);  // 把 buf 中的过滤方式写到相应的地方,准备供 yyparse() 函数使用。
      }
    }
  }

  init_linktype();
  pcap_parse() {
    yyparse(); // 把过滤的字符串进行编码
  } 
}

 

以上是关于libpcap 过滤 pcap_compile的主要内容,如果未能解决你的问题,请参考以下文章

基于Libpcap实现一个网络数据包嗅探器

tcpdump 协议过滤哪些协议

winpcap抓包原理

python调用tcpdump抓包过滤

推荐几款经典的 Linux 收包引擎

libpcap 的 bpf