我想用替罪羊重建一个包裹。如果我将原始数据包与构造的数据包进行比较,我会发现包的一个层中有几个条目有错误的值。我认为它来自于一些值的不合适的数据类型,如以下所示:
如果我用这样的字符串打印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.
这两个符号有什么区别?
请帮帮忙
发布于 2017-07-05 16:58:52
\x<hex_byte>是一种特殊的转义序列,用于将文字字节表示为十六进制数字。
第一个实质上是向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 -通过将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.当然,您可以使用相同的技术来获取任意多个不同的随机字节。
https://stackoverflow.com/questions/44931796
复制相似问题