【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个?
问题解答
回答1:经过查阅资料,我发现要用个函数实现rawstring转string,即可。
raw = raw.replace(’’’,’’)string = raw.decode(’string_escape’)
输出的结果就正确了
相关文章:
1. web - nginx location 搜索算法问题!?2. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!3. docker-machine添加一个已有的docker主机问题4. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题5. 关于docker下的nginx压力测试6. debian - docker依赖的aufs-tools源码哪里可以找到啊?7. docker - 各位电脑上有多少个容器啊?容器一多,自己都搞混了,咋办呢?8. docker安装后出现Cannot connect to the Docker daemon.9. docker - 如何修改运行中容器的配置10. angular.js - angular内容过长展开收起效果

网公网安备