欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于python+scapy抓包與解析

 更新時間:2023年08月24日 10:36:50   作者:B0t0w1  
這篇文章主要介紹了關(guān)于python+scapy抓包與解析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

最近一直在使用做流量分析,今天把 scapy 部分做一個總結(jié)。

Python 的 scapy 庫可以方便的抓包與解析包,無奈資料很少,官方例子有限,大神博客很少提及, 經(jīng)過一番嘗試后,總結(jié)以下幾點用法以便大家以后使用。

python scapy抓包與解析

作為初學(xué)者,關(guān)心的首先是如何安裝,本人電腦系統(tǒng)是 fedora, 建議使用 linux。

推薦下載 pip,直接:(當(dāng)然得在 su 權(quán)限下)

pip install scapy

在 terminal 中輸入 scapy, 如果有下面形式即安裝好了:

抓包

from scapy.all import *
dpkt = sniff(iface = "wlp7s0", count = 100)

sniff() 是 scapy 內(nèi)置函數(shù),有很多參數(shù), 如圖:

這里就不一一解釋, iface 參數(shù)是網(wǎng)卡信息, 也就是 eth0 之類的, 我這里是 wlp7s0, count 參數(shù)是抓取的連接數(shù)量, 這里是 100, 還有 filter 參數(shù)是過濾等。

pcap 格式保存

wrpcap("demo.pcap", dpkt)

pcap 格式較為通用, 可以將上述抓取的包保存為 pcap,dpkt 是上面抓取的流量變量。

數(shù)據(jù)包解析

可以看到有 94 個 tcp 包, 4個 udp 包, 還有兩個其他類型的包。

類似于 python 中的 list 類型, 可以使用下標(biāo)訪問, 比如用 python 可寫個 for 循環(huán)遍歷每個連接。

長度可以使用 len 計算

注意這里 dpkt 不是 list 類型, 也不是 string 類型, 因此如果要進(jìn)行字符串處理,要把它轉(zhuǎn)換為 string 類型,

scapy強大地方在于可以通過字段來查看每一個字段信息,首先我們看一下它有那些字段:

可以使用 ls() 查看支持的協(xié)議類型,有很多,具體看幾個:

甚至還有硬件信息:

還有很多, 可以自己去看一下, 不附圖了。

知道它有那些字段后, 就可以調(diào)用了,隨便舉個例子, 比如第四個連接 dpkt[3]

它的結(jié)構(gòu)非常清楚,首先是 Ether 層, 然后是 IP 層, 然后是 TCP 層,訪問時就按張如圖就可以訪問各個字段信息。

要注意的是, 不是所有連接都是這幾個層, Ether 是都有的, 但是 udp 連接肯定就沒有 TCP 層, 而是改為 udp 層, ARP 包肯定就沒有 IP 層, 更沒有 TCP 層,如果再 arp 連接使用 dpkt[i][IP] 就會報錯, 因為它沒有 IP 這一層。

python 使用時可以時使用 ether 的 type 判斷是不是 IP 包, 使用 ip 的 proto 判斷時 tcp 還是 udp。

訪問包中的報文可以使用 dpkt[i][Raw].load 字段, (假設(shè)第 i +1 個包有報文信息),同樣,如果沒有報文信息, 就沒有 Raw 這一層,也就沒有 load 這一字段。比如這里:

第六個連接并沒有 Raw 數(shù)據(jù),訪問出錯, 第七個有 Raw 數(shù)據(jù),可以得到報文信息。

使用離線數(shù)據(jù)包

pcap = sniff(offline = "xx/xx.pcap")`

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python搜索指定目錄的方法

    python搜索指定目錄的方法

    這篇文章主要介紹了python搜索指定目錄的方法,涉及Python操作目錄的相關(guān)技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • Python下載的11種姿勢(小結(jié))

    Python下載的11種姿勢(小結(jié))

    這篇文章主要介紹了Python下載的11種姿勢(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Python使用type動態(tài)創(chuàng)建類操作示例

    Python使用type動態(tài)創(chuàng)建類操作示例

    這篇文章主要介紹了Python使用type動態(tài)創(chuàng)建類操作,結(jié)合實例形式詳細(xì)分析了Python使用type動態(tài)創(chuàng)建類的具體原理、實現(xiàn)方法與操作注意事項,需要的朋友可以參考下
    2020-02-02
  • Python中字符串切片詳解

    Python中字符串切片詳解

    這篇文章主要介紹了Python中字符串切片,在python中定義個字符串然后把它賦值給一個變量。我們可以通過下標(biāo)訪問單個的字符,跟所有的語言一樣,下標(biāo)從0開始。這時我們可以通過切片方式來截取出我們定義的字符串的一部分,下面小編將為大家詳細(xì)介紹,需要的朋友可以參考下
    2021-10-10
  • 在?Python?中使用通配符匹配字符串的方法

    在?Python?中使用通配符匹配字符串的方法

    這篇文章主要介紹了在?Python?中使用通配符匹配字符串的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • python模擬登陸阿里媽媽生成商品推廣鏈接

    python模擬登陸阿里媽媽生成商品推廣鏈接

    這篇文章主要介紹了python模擬登陸阿里媽媽生成商品推廣鏈接,需要的朋友可以參考下
    2014-04-04
  • 詳解python字節(jié)碼

    詳解python字節(jié)碼

    本篇文章給大家總結(jié)了關(guān)于python字節(jié)碼的相關(guān)知識點以及知識點分析,對此有需要的朋友參考學(xué)習(xí)下。
    2018-02-02
  • python PyAUtoGUI庫實現(xiàn)自動化控制鼠標(biāo)鍵盤

    python PyAUtoGUI庫實現(xiàn)自動化控制鼠標(biāo)鍵盤

    這篇文章主要介紹了python PyAUtoGUI庫實現(xiàn)自動化控制鼠標(biāo)鍵盤,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-09-09
  • 教你利用PyTorch實現(xiàn)sin函數(shù)模擬

    教你利用PyTorch實現(xiàn)sin函數(shù)模擬

    這篇文章主要給大家介紹了關(guān)于教你利用PyTorch實現(xiàn)sin函數(shù)模擬的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-01-01
  • 機器學(xué)習(xí)之?dāng)?shù)據(jù)清洗及六種缺值處理方式小結(jié)

    機器學(xué)習(xí)之?dāng)?shù)據(jù)清洗及六種缺值處理方式小結(jié)

    本文主要介紹了機器學(xué)習(xí)之?dāng)?shù)據(jù)清洗及六種缺值處理方式小結(jié),包括刪除空行、填充平均值、中位數(shù)、眾數(shù)、線性插值和隨機森林填充,具有一定的參考價值,感興趣的可以了解一下
    2025-03-03

最新評論