【python|scapy】sprintf输出时raw_string转string

最近在有python的scapy模块分析TCP报文,一直有一个关于转义字符的问题困惑着我,查找的很多资料后仍然百思不得其解,请大神指教。
请看代码:

from scapy.all import *

def findTCPdata(pkt):

raw = pkt.sprintf("%Raw.load%")

print raw

print 'length of TCP data: '+ str(len(raw))

def main():

pkts = rdpcap('XXX.pcap')

for pkt in pkts:

findTCPdata(pkt)

if __name__ == '__main__':

main()

结果为:
图片描述

打印出的字符串中‘\x11’、'\x04'等等应该相当于一个字符,但是解释器把它们当成了4个字符。所以四条报文中的tcp数据长度不是17而成了为53,52,46,52。
查阅scapy源码发现sprintf("%Raw.load%")函数实现提取tcp数据段,并将其转化为字符串,但是转化后的结果类似于raw_string,字符串中的‘\x’失效了,被当做了2个字符。
请问该怎么转化,使得转义字符‘\x’生效,使得类似‘\x11’、'\x04'等等的字符被看做一个字符而不是4个?

回答:

经过查阅资料,我发现要用个函数实现rawstring转string,即可。

raw = raw.replace('\'','')

string = raw.decode('string_escape')

输出的结果就正确了

以上是 【python|scapy】sprintf输出时raw_string转string 的全部内容, 来源链接: utcz.com/a/162056.html

回到顶部