日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

cap文件的格式說明

系統(tǒng) 1912 0

前面24個(gè)字節(jié)是.cap文件的文件頭。

頭信息對應(yīng)的結(jié)構(gòu)體為:
struct pcap_file_header {
? bpf_u_int32 magic;
? u_short version_major;
? u_short version_minor;
? bpf_int32 thiszone; /* gmt to local correction */
? bpf_u_int32 sigfigs; /* accuracy of timestamps */
? bpf_u_int32 snaplen; /* max length saved portion of each pkt */
? bpf_u_int32 linktype; /* data link type (LINKTYPE_*) */
};

cap文件中的linktype很重要,不同的網(wǎng)絡(luò)環(huán)境下抓包,數(shù)據(jù)幀的幀頭是不一樣的。
在局域網(wǎng)內(nèi)抓包,linktype為1 ( DLT_EN10MB, Ethernet (10Mb) ),以太網(wǎng)的幀頭就是兩個(gè)網(wǎng)卡物理地址;
如果直接用ADSL撥號上線,則linktype為9 ( DLT_PPP, Point-to-point Protocol),數(shù)據(jù)幀頭為PPP協(xié)議。
關(guān)于linktype支持的類型,可以參考pcap-bpf.h中定義的以DLT_開頭的宏。


========================================================================

頭信息后是順序的每個(gè)數(shù)據(jù)段的信息,每個(gè)數(shù)據(jù)段中包含抓包時(shí)間、包類型等信息,然后是包的內(nèi)容。
struct pcap_pkthdr {
struct timeval ts; /* time stamp */
bpf_u_int32 caplen; /* length of portion present */
bpf_u_int32 len; /* length this packet (off wire) */
};
ts為抓包的時(shí)間;
caplen和len我發(fā)現(xiàn)一般都是一樣的。(什么情況下會不一樣還沒搞懂)

16字節(jié)的數(shù)據(jù)段頭之后就是包的信息了。例子中的包信息是局域網(wǎng)中抓的,所以是以太網(wǎng)幀頭,結(jié)構(gòu)體如下:
struct EthernetPacket
{
char MacDst[6]; ///< 目的網(wǎng)卡物理地址
char MacSrc[6]; ///< 源網(wǎng)卡物理地址
unsigned short PacketType; ///< 包類型, ip或ARP等
};
PacketType=0x0008是IP包,PacketType=0x0608是ARP包。

?

cap文件的格式說明

紅色框內(nèi)為?pcap_file_header?

綠色框內(nèi)為?pcap_pkthdr

后面為包內(nèi)數(shù)據(jù)

注意兩個(gè)長度,一個(gè)是高位在后,一個(gè)是高位在前,后邊長度不包含IP頭長度

?

cap文件的格式說明


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 崇阳县| 岫岩| 镇巴县| 新巴尔虎右旗| 大新县| 鲁甸县| 理塘县| 平凉市| 渭南市| 沅陵县| 宜黄县| 瓦房店市| 奈曼旗| 伊金霍洛旗| 博白县| 高淳县| 元朗区| 三明市| 崇文区| 龙口市| 陇川县| 平乡县| 韶山市| 佛坪县| 湟中县| 保德县| 丹阳市| 崇阳县| 南京市| 平阴县| 金溪县| 淮阳县| 东平县| 潍坊市| 高平市| 紫云| 云阳县| 公安县| 扶风县| 陆丰市| 朝阳市|