Microsoft Visual Studio 10.0執行WinPcap擷取網路設配器的代碼

來源:互聯網
上載者:User

標籤:microsoft   應用程式   網路應用   作業系統   資料包   

    WinPcap是一個基於Win32平台的,用於捕獲網路資料包並進行分析的開源庫.

大多數網路應用程式通過被廣泛使用的作業系統元件來訪問網路,比如sockets。  這是一種簡單的實現方式,因為作業系統已經妥善處理了底層具體實現細節(比如協議處理,封裝資料包等等),並且提供了一個與讀寫檔案類似的,令人熟悉的介面。

然而,有些時候,這種“簡單的方式”並不能滿足任務的需求,因為有些應用程式需要直接存取網路中的資料包。也就是說,那些應用程式需要訪問未經處理資料包,即沒有被作業系統利用網路通訊協定處理過的資料包。

WinPcap產生的目的,就是為Win32應用程式提供這種訪問方式; WinPcap提供了以下功能

  • 捕獲未經處理資料包,無論它是發往某台機器的,還是在其他裝置(共用媒介)上進行交換的

  • 在資料包發送給某應用程式前,根據使用者指定的規則過濾資料包

  • 將未經處理資料包通過網路發送出去

  • 收集並統計網路流量資訊

以上這些功能需要藉助安裝在Win32核心中的網路裝置驅動程式才能實現,再加上幾個動態連結程式庫DLL。

所有這些功能都能通過一個強大的編程介面來表現出來,易於開發,並能在不同的作業系統上使用。這本手冊的主要目標是在一些程式範例的協助下,敘述這些編程介面的使用。  

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

   首先配置Microsoft Visual Studio 10.0

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

配置屬性-->清單工具-->輸入和輸出-->嵌入清單-->否

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

配置屬性-->C/C++-->常規-->附加元件封裝含目錄-->

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

配置屬性-->連結器-->常規-->附加庫目錄-->

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

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

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

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

650) this.width=650;" src="http://s4.51cto.com/wyfs02/M00/89/49/wKioL1gPCTeRj0TAAAAnbKqqyRo554.png-wh_500x0-wm_3-wmp_4-s_775444348.png" title="捕獲.PNG" alt="wKioL1gPCTeRj0TAAAAnbKqqyRo554.png-wh_50" />



Microsoft Visual Studio 10.0執行WinPcap擷取網路設配器的代碼

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.