獲取設備列表

   

 通常,編寫基於WinPcap應用程序的第一件事情,就是獲得已連接的網絡適配器列表。libpcap和WinPcap都提供了 pcap_findalldevs_ex() 函數來實現這個功能: 這個函數返回一個 pcap_if 結構的鏈表, 每個這樣的結構都包含了一個適配器的詳細信息。值得注意的是,數據域 namedescription 表示一個適配器名稱和一個可以讓人們理解的描述。

下列代碼能獲取適配器列表,並在屏幕上顯示出來,如果沒有找到適配器,將打印錯誤信息。

#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++-->常規-->附加包含目錄-->

wKioL1gPC6uTJJxpAAALE1UqGpU468.png


項目-->**屬性(alt+F7)

配置屬性-->鏈接器-->常規-->附加庫目錄-->

wKiom1gPC83wk1NAAAAKQg8uuUY968.png


項目-->**屬性(alt+F7)

配置屬性-->鏈接器-->輸入-->附加依賴項-->補充“;Packet.lib;wpcap.lib”


項目-->**屬性(alt+F7)

配置屬性-->C/C++-->預處理器-->預處理器定義-->補充“;HAVE_REMOTE”



運行結果(Ctrl+F5)

wKiom1gPDBSTT-3LAAAbg4pz_zc347.png


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章