需要删除线条直到模式匹配

需要删除线条直到模式匹配

我的 C 代码需要解码另一个应用程序通过套接字接收的一些应用程序数据。我使用 Wireshark 将数据包(许多)导出到 C 数组中。但该数组包含包含 IP 地址/端口的所有字节。我只需要应用程序数据。

C 数组是:

静态常量无符号字符 pkt64[393] = {
0x00, 0x04, 0x00, 0x01, 0x00, 0x06, 0xd8, 0x9d, /* ........ */
0x67, 0x16, 0x55, 0xc0, 0x00, 0x00, 0x08, 0x00, /* gU.... */
0x45, 0x00, 0x01, 0x79, 0xf1, 0x09, 0x40, 0x00, /* E..y..@。 */
0x40, 0x06, 0xc1, 0xee, 0x0a, 0x17, 0x6f, 0x35, /* @.....o5 */
0x0a, 0xd7, 0x02, 0x64, 0xe3, 0xa4, 0x18, 0x54, /* ...d...T */
0x8c, 0xa2, 0xd6, 0xb1, 0xe9, 0xa5, 0x0c, 0xd2, /* ........ */
0x80, 0x18, 0x14, 0x12, 0x87, 0xf2, 0x00, 0x00, /* ........ */
0x01, 0x01, 0x08, 0x0a, 0x4a, 0x0c, 0x9a, 0x21, /* ....J..! */
0x94、0x8d、0xb2、0x23、0x01、0x43、0x60、0x00、/* ...#.C`. */
0x06、0x00, 0x58, 0x6f, 0x12, 0x00, 0x30, 0x30, /* ..Xo..00 */
0x47, 0x00, 0x20, 0xe2, 0x82, 0x19, 0x00, 0x10, /* G...... */
0x10, 0x00, 0x00, 0x00, 0x00, 0x13, 0x00, 0x95, /* ........ */
0x42, 0x38, 0x14, 0x04, 0x24, 0x11, 0x57, 0x14, /* B8..$.W. */
0x58, 0x12, 0x30, 0x30, 0x11, 0x00, 0x40, 0x00, /* X.00..@. */
[...]
0x39、0x38、0x35、0x2d、0x31、0x31、0x37、0x00、/* 985-117。 */
0x03, 0x14, 0x10, 0x00, 0x00, 0x03, 0x28, 0x00, /* ......(. */
0x01, 0x19, 0x95, 0xe2, 0xcf, 0x53, 0x13, 0xa2, /* .....S.. */
0xd5 /* . */
};

我的应用程序数据以 bytes 开头0x60, 0x00, 0x06, 0x00。因此,我需要删除直到感兴趣的应用程序数据为止的所有行和字节。由于我有很多数据包需要解码,如何使用grep/sed来实现我的要求?

答案1

要删除前 70 个字节:

perl -0777 -pe 's{(?:0x[0-9a-f]{2},\s*(?:/\*.*?\*/)?\s*){70}}{}'

删除直到第一个0x60, 0x00, 0x06, 0x00

perl -0777 -pe 'BEGIN{$c=qr{,\s*(?:/\*.*?\*/)?\s*}}
  s/{(?s:.*?)(?=0x60${c}0x00${c}0x06${c}0x00)/{/'

相关内容