国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

【python|scapy】sprintf輸出時raw_string轉string

瀏覽:166日期:2022-09-16 08:26:26

問題描述

最近在有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()

結果為:【python|scapy】sprintf輸出時raw_string轉string

打印出的字符串中‘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’)

輸出的結果就正確了

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 欧美激情成人网 | 最新最好看免费毛片基地 | 欧美一区二区三区高清视频 | 日本韩国中文字幕 | 亚洲人成在线免费观看 | 美女操男人 | 国产不卡视频在线观看 | 91亚洲精品国产第一区 | 久久精品国产精品亚洲20 | 波多野结衣免费观看视频 | 美女视频在线观看黄 | 久久毛片久久毛 | 国产精品手机视频一区二区 | 国产一级做a爰片久久毛片 国产一级做a爰片久久毛片99 | 欧美在线视频观看 | 高清国产精品久久久久 | 国产碰碰 | 91精品视品在线播放 | 深夜福利视频在线观看免费播放 | 亚洲欧美日韩专区 | 黄色三级视频网站 | 亚洲精品一区二区在线播放 | 国产做爰一区二区 | 成年女人色毛片免费 | 欧美成网 | 久久国产乱子伦精品免费不卡 | 国产日韩精品视频 | 国产美女一区二区在线观看 | 日本理论片午夜论片 | 欧美黄视频在线观看 | 国产呦精品系列在线 | 欧美特级毛片aaaa | 国产精品久久久天天影视香蕉 | 亚洲美女综合 | 在线观看的毛片 | 特级毛片全部免费播放器 | 亚洲成人在线播放视频 | 日本精品视频一视频高清 | 欧美日韩在线观看一区二区 | 成人欧美一区二区三区视频 | 毛片免费的 |