数据包层中的数据类型错误(scapy)

wrong data type in packet layer (scapy)

我想用scapy重构一个数据包。如果我将原始数据包与构建的数据包进行比较,我会发现数据包层中的一些条目具有错误的值。我认为它来自某些值的不合适数据类型,例如以下值:

如果我像这样在一个字符串中打印 stream_id

stream_id = "\x00\x22\x97\x04\x06\xba\x00\x00"

输出不可读(如翼形符号)。

但是如果我自己把stream_id放在一起

alias = "CB"
stream_id = '\x' + alias + '\x' + alias + '\x' + alias + '\x' + alias

打印输出为\x9B\x9B\x9B\x9B.

这两种表示法有什么区别?

请帮忙

\x<hex_byte> 是 Python 字符串的特殊转义序列,将文字字节表示为十六进制数字。

第一个本质上是将字节写入您的 stream_id,例如:

stream_id_1 = "\x00\x22\x97\x04\x06\xba\x00\x00"
stream_id_2 = chr(0x00) + chr(0x22) + chr(0x97) + chr(0x04) \
              + chr(0x06) + chr(0xba) + chr(0x00) + chr(0x00)

assert stream_id_1 == stream_id_2  # passes

如果你打印出你得到的字节:0022970406ba0000

而第二个是写一个字符串,就像你写的一样(使用与上面相同的数据):

stream_id_1 = "\x00\x22\x97\x04\x06\xba\x00\x00"

转义转义序列,这样数字就不会被解释为字节,从而导致以下打印输出:5c7830305c7832325c7839375c7830345c7830365c7862615c7830305c783030如您所见,这是一个截然不同的结构。

UPDATE - 要构建字节流,您可以像在 'manually' 构建的字符串中那样构建它们 - 通过将 alias 转换为整数和然后使用 chr() 将其转换为字节字符:

alias = chr(int("CB", 16))
stream_id = alias + alias + alias + alias  # etc.

但是根据您的评论判断,您只想获得一个随机字节,所以不要通过生成十六进制字符串浪费周期,然后将其转换为整数,最后将其转换为字节字符 - 获得一个随机整数立即将其转换为字节字符:

alias = chr(random.randint(0, 255))
stream_id = alias + alias + alias + alias  # etc.

或者更好的是,放弃 random 模块并使用 os.urandom() 代替:

import os

alias = os.urandom(1)
stream_id = alias + alias + alias + alias  # etc.

当然,您可以使用相同的技术来获取任意数量的不同随机字节。