第一:打開VS2010,創建一個新的項目,再對VS做一些設置。如下:
項目-->**屬性(alt+F7)
配置屬性-->清單工具-->輸入和輸出-->嵌入清單-->否
項目-->**屬性(alt+F7)
配置屬性-->C/C++-->常規-->附加包含目錄-->
項目-->**屬性(alt+F7)
配置屬性-->鏈接器-->常規-->附加庫目錄-->
項目-->**屬性(alt+F7)
配置屬性-->鏈接器-->輸入-->附加依賴項-->補充“;Packet.lib;wpcap.lib;Ws2_32.lib;”
項目-->**屬性(alt+F7)
配置屬性-->C/C++-->預處理器-->預處理器定義-->補充“;HAVE_REMOTE”
-----------------------------------------------------------------------------------------------------------
------------------LINK:fatal error LNK1123: 轉換到 COFF 期間失敗: 文件無效或損壞---------------------------
第一步:將 項目——項目屬性——配置屬性——連接器——清單文件——嵌入清單 “是”改爲“否”。若還不能解決問題進入第二步。
第二步:查看計算機是否爲64bit操作系統,如是,繼續如下操作。
查找是否有兩個cvtres.exe。
C:\Program Files(x86)\Microsoft Visual Studio 10.0\vc\bin\cvtres.exe
C:\Windows\Microsoft.NET\Framework\v4.0.30319\cvtres.exe
右鍵屬性—詳細信息, 查看兩者版本號,刪除/重命名較舊的版本,或者重新設置Path變量。
治本的辦法是第二步,刪除舊版本的cvtres.exe後,就不需要每次都設置配置了。
例如: del C:\"Program Files (x86)"\"Microsoft Visual Studio 10.0"\VC\bin\cvtres.exe
--------------------------------------------------------------------------------------------------------
第二步:把WinPcap 中分析數據包的代碼複製到VS中,再把WinPcap中數據分析中的一些關於網卡打印的代碼複製到VS中。
// mist12306.cpp : 定義控制檯應用程序的入口點。
//
#include "stdafx.h"
#include <stdlib.h>
#include <stdio.h>
#include <pcap.h>
void main(int argc, char **argv)
{
pcap_t *fp;
char errbuf[PCAP_ERRBUF_SIZE];
u_char packet[100];
int i;
pcap_if_t *alldevs;
pcap_if_t *d;
int inum;
int j=0;
pcap_t *adhandle;
/* 獲得設備列表 */
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", ++j, d->name);
if (d->description)
printf(" (%s)\n", d->description);
else
printf(" (No description available)\n");
}
if(j==0)
{
printf("\nNo interfaces found! Make sure WinPcap is installed.\n");
return ;
}
printf("Enter the interface number (1-%d):",j);
scanf("%d", &inum);
if(inum < 1 || inum > j)
{
printf("\nInterface number out of range.\n");
/* 釋放設備列表 */
pcap_freealldevs(alldevs);
return ;
}
/* 跳轉到已選設備 */
for(d=alldevs,j=0; j< inum-1 ;d=d->next, j++);
/* 打開輸出設備 */
if ( (fp= pcap_open(d->name, // 設備名
100, // 要捕獲的部分 (只捕獲前100個字節)
PCAP_OPENFLAG_PROMISCUOUS, // 混雜模式
1000, // 讀超時時間\
NULL, // 遠程機器驗證
errbuf // 錯誤緩衝
) ) == NULL)
{
fprintf(stderr,"\nUnable to open the adapter. %s is not supported by WinPcap\n",d->name);
return;
}
/* 假設在以太網上,設置MAC的目的地址爲 1:1:1:1:1:1 */
packet[0]=255;
packet[1]=255;
packet[2]=255;
packet[3]=255;
packet[4]=255;
packet[5]=255;
/* 設置MAC源地址爲 2:2:2:2:2:2 */
packet[6]=91;
packet[7]=91;
packet[8]=91;
packet[9]=91;
packet[10]=91;
packet[11]=91;
packet[12]=96;
packet[13]=00;
/* 填充剩下的內容 */
for(i=14;i<100;i++)
{
packet[i]=i%256;
}
/* 發送數據包 */
if (pcap_sendpacket(fp, packet, 100 /* size */) != 0)
{
fprintf(stderr,"\nError sending the packet: \n", pcap_geterr(fp));
return;
}
return;
}
第三步:運行後選擇第二塊網卡,再打開wireshark普貨數據包。
總結:對代碼不理解 ,感覺難難難!