WinPcap捕获数据包
生活随笔
收集整理的這篇文章主要介紹了
WinPcap捕获数据包
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
首先使用pcap_open打開指定的網卡, 獲取使用pcap_loop進行捕獲數據包.
// pcap_loop.cpp : 定義控制臺應用程序的入口點。 //#include "stdafx.h"#define HAVE_REMOTE #include <pcap.h>/* packet handler 函數原型 */ void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data);#pragma comment(lib,"wpcap.lib")int _tmain(int argc, _TCHAR* argv[]) {pcap_if_t *alldevs;pcap_if_t *d;int inum;int i=0;pcap_t *adhandle;char errbuf[PCAP_ERRBUF_SIZE];/* 獲取本機設備列表 */if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL, &alldevs, errbuf) == -1){fprintf(stderr,"Error in pcap_findalldevs: %s\n", errbuf);exit(1);}/* 打印列表 */for(d=alldevs; d; d=d->next){printf("%d. %s", ++i, d->name);if (d->description)printf(" (%s)\n", d->description);elseprintf(" (No description available)\n");}if(i==0){printf("\nNo interfaces found! Make sure WinPcap is installed.\n");return -1;}printf("Enter the interface number (1-%d):",i);scanf("%d", &inum);if(inum < 1 || inum > i){printf("\nInterface number out of range.\n");/* 釋放設備列表 */pcap_freealldevs(alldevs);return -1;}/* 跳轉到選中的適配器 */for(d=alldevs, i=0; i< inum-1 ; d=d->next, i++);/* 打開設備 */if ( (adhandle= pcap_open(d->name, // 設備名65535, // 65535保證能捕獲到不同數據鏈路層上的每個數據包的全部內容PCAP_OPENFLAG_PROMISCUOUS, // 混雜模式1000, // 讀取超時時間NULL, // 遠程機器驗證errbuf // 錯誤緩沖池) ) == NULL){fprintf(stderr,"\nUnable to open the adapter. %s is not supported by WinPcap\n", d->name);/* 釋放設備列表 */pcap_freealldevs(alldevs);return -1;}printf("\nlistening on %s...\n", d->description);/* 釋放設備列表 */pcap_freealldevs(alldevs);/* 開始捕獲 */pcap_loop(adhandle, 0, packet_handler, NULL);getchar();return 0; }/* 每次捕獲到數據包時,libpcap都會自動調用這個回調函數 */ void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data) {struct tm *ltime;char timestr[16];time_t local_tv_sec;/* 將時間戳轉換成可識別的格式 */local_tv_sec = header->ts.tv_sec;ltime=localtime(&local_tv_sec);strftime( timestr, sizeof timestr, "%H:%M:%S", ltime);printf("%s,%.6ld len:%d\n", timestr, header->ts.tv_usec, header->len);}總結
以上是生活随笔為你收集整理的WinPcap捕获数据包的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: WinPcap获取网卡的更多信息
- 下一篇: WinPcap pcap_next_ex