数据包层中的数据类型错误(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.
当然,您可以使用相同的技术来获取任意数量的不同随机字节。
我想用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.
当然,您可以使用相同的技术来获取任意数量的不同随机字节。