【问题标题】:Calculate size and start of TCP packet data (excluding header)计算 TCP 数据包数据的大小和开始(不包括标头)
【发布时间】:2011-10-02 03:49:43
【问题描述】:

我将如何计算 TCP 数据包中数据的大小和起始字节(不包括标头信息)?

【问题讨论】:

    标签: networking tcp


    【解决方案1】:

    我将假设您正在处理 TCP/IP 数据包。您需要自己计算这个尺寸。

    IP header 有一个“总长度”字段,它为您提供整个 IP 数据包的长度(以字节为单位)。如果你减去构成报头的 32 位字的数量(由 IP 报头中的报头长度字段给出),你将知道 TCP 数据包的大小。通常,IP 数据包的标头为 20 字节,除非存在选项。

    TCP header 中,Data Offset 字段以 32 位字指定 TCP 标头的大小。同样,您可以从之前计算的 TCP 数据包大小中减去该数字(乘以 4 得到标头中的字节数),得到 TCP 数据包中数据的大小。

    给定 IP 标头中的标头长度和 TCP 标头中的数据偏移量,您可以将这两者相加并乘以 4 得到字节偏移量,直到 TCP 数据包中的数据开始。

    【讨论】:

    • 所以 [IP 总长度] - ( ([IP IHL] + [TCP 数据偏移]) * 4 ) ?
    • @RobertJacobs 这似乎是大小,是的。
    【解决方案2】:

    我刚刚在路由器上捕获了一个 TCP 数据包,然后我计算了 TCP 数据长度。

    IHL = 5
    Total Length = 0x00a8
    Data Offset = 8
    ---------------------
    0x00a8 - (5 + 8) * 4 = 116 bytes
    

    # tcpdump -n -i br-lan -c 1 -e -XX tcp port 22
    tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
    listening on br-lan, link-type EN10MB (Ethernet), capture size 65535 bytes
    15:33:53.917593 ae:ca:87:aa:aa:aa > b8:e8:56:bb:bb:bb, ethertype IPv4 (0x0800), length 182: 192.168.31.1.22 > 192.168.31.102.54076: Flags [P.], seq 582717816:582717932, ack 442380252, win 4706, options [nop,nop,TS val 100656432 ecr 1139948861], length 116
        0x0000:  b8e8 56bb bbbb aeca 87aa aaaa 0800 4510  ..V........x..E.
                                                     ^
        0x0010:  00a8 8d0c 4000 4006 ed7b c0a8 1f01 c0a8  ....@.@..{......
                 ^^^^
        0x0020:  1f66 0016 d33c 22bb 9178 1a5e 2fdc 8018  .f...<"..x.^/...
                                                    ^
        0x0030:  1262 c052 0000 0101 080a 05ff e530 43f2  .b.R.........0C.
        0x0040:  3d3d f6e4 f672 736f 6c6c 191f 64ec 80a6  ==...rsoll..d...
        0x0050:  ba74 e8f7 b2ce 99ec 2725 2d49 f4f6 7760  .t......'%-I..w`
        0x0060:  c83f 5130 83bb ca22 c32c 6251 7381 08e2  .?Q0...".,bQs...
        0x0070:  c036 1c12 f22f fe8b c36a eeff c95c 36fa  .6.../...j...\6.
        0x0080:  7baa 810b 4c75 8ccf 19e4 62df 2c2c c5fd  {...Lu....b.,,..
        0x0090:  a0c8 aa53 1130 d413 7097 f1cd 34dc 92b7  ...S.0..p...4...
        0x00a0:  ea9b 3bd6 02f8 ea93 c8f3 7d32 4a58 39aa  ..;.......}2JX9.
        0x00b0:  12d3 e2bd 18d4                           ......
    

    整个以太网框架

    IP 标头(IHL / 总长度)

    0                   1                   2                   3   
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |Version|**IHL**|Type of Service|**********Total Length*********|
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |         Identification        |Flags|      Fragment Offset    |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |  Time to Live |    Protocol   |         Header Checksum       |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                       Source Address                          |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                    Destination Address                        |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                    Options                    |    Padding    | <-- optional
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                            DATA ...                           |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    

    TCP 头(数据偏移)

    0                   1                   2                   3   
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |          Source Port          |       Destination Port        |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                        Sequence Number                        |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                    Acknowledgment Number                      |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |  Data |       |C|E|U|A|P|R|S|F|                               |
    | Offset|  Res. |W|C|R|C|S|S|Y|I|            Window             | 
    | ******|       |R|E|G|K|H|T|N|N|                               |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |           Checksum            |         Urgent Pointer        |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                    Options                    |    Padding    |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    |                             data                              |
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    

    【讨论】:

      猜你喜欢
      • 2011-07-16
      • 2016-03-19
      • 1970-01-01
      • 2019-01-30
      • 2020-05-25
      • 2010-12-23
      • 2019-06-27
      • 2011-04-18
      • 2010-09-28
      相关资源
      最近更新 更多