通常,編寫基於WinPcap應用程序的第一件事情,就是獲得已連接的網絡適配器列表。libpcap和WinPcap都提供了 pcap_findalldevs_ex() 函數來實現這個功能: 這個函數返回一個 pcap_if 結構的鏈表, 每個這樣的結構都包含了一個適配器的詳細信息。值得注意的是,數據域 name 和 description 表示一個適配器名稱和一個可以讓人們理解的描述。
下列代碼能獲取適配器列表,並在屏幕上顯示出來,如果沒有找到適配器,將打印錯誤信息。
#include "stdafx.h"
#include "pcap.h"
int _tmain(int argc, _TCHAR* argv[])
{
pcap_if_t *alldevs;
pcap_if_t *d;
int i=0;
char errbuf[PCAP_ERRBUF_SIZE];
/* 獲取本地機器設備列表 */
if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL /* auth is not needed */, &alldevs, errbuf) == -1)
{
fprintf(stderr,"Error in pcap_findalldevs_ex: %s\n", errbuf);
exit(1);
}
/* 打印列表 */
for(d= alldevs; d != NULL; d= d->next)
{
printf("%d. %s", ++i, d->name);
if (d->description)
printf(" (%s)\n", d->description);
else
printf(" (No description available)\n");
}
if (i == 0)
{
printf("\nNo interfaces found! Make sure WinPcap is installed.\n");
return 0;
}
/* 不再需要設備列表了,釋放它 */
pcap_freealldevs(alldevs);
}
有關這段代碼的一些說明
首先, pcap_findalldevs_ex() ,和其他libpcap函數一樣,有一個 errbuf 參數。一旦發生錯誤,這個參數將會被libpcap寫入字符串類型的錯誤信息。
第二要記住,不是所有的操作系統都支持libpcap提供的網絡程序接口,因此,如果我們想編寫一個可移植的應用程序,我們就必須考慮在什麼情況下, description 是 null。本程序中,我們遇到這種情況時,會打印提示語句"No description available"。
最後要記住,當我們完成了設備列表的使用,我們要調用 pcap_freealldevs() 函數將其佔用的內存資源釋放。
在運行這個程序過程中會遇到一些錯誤,以下是解決錯誤的幾個步驟
項目-->**屬性(alt+F7)
配置屬性-->清單工具-->輸入和輸出-->嵌入清單-->否
項目-->**屬性(alt+F7)
配置屬性-->C/C++-->常規-->附加包含目錄-->
項目-->**屬性(alt+F7)
配置屬性-->鏈接器-->常規-->附加庫目錄-->
項目-->**屬性(alt+F7)
配置屬性-->鏈接器-->輸入-->附加依賴項-->補充“;Packet.lib;wpcap.lib”
項目-->**屬性(alt+F7)
配置屬性-->C/C++-->預處理器-->預處理器定義-->補充“;HAVE_REMOTE”
運行結果(Ctrl+F5)