1. 程式人生 > 程式設計 >C# 實現抓包的例項程式碼

C# 實現抓包的例項程式碼

工具:SharpPcap 4.2.0

vs工程:控制檯應用程式

關於C#抓包,我只找到SharpPcap 這個dll,相關的資料不多,而且都是挺老的,所以就順手記一下自己的程式碼,給有同樣需求的人一個參考吧。

當然,程式碼可能存在問題,請見諒。

一、獲取連線裝置

// 獲取連線列表
CaptureDeviceList devices = CaptureDeviceList.Instance;

// 無連線
if (devices.Count < 1)
{
  Console.WriteLine("No devices were found on this machine");
  return;
}

Console.WriteLine("\n以下為本機連線:");
Console.WriteLine("--------------\n");

int j=0;
string temp = "";
Regex r = new Regex("FriendlyName: .*\n"); //匹配連線的FriendlyName
Match m;
// 列印連線裝置
foreach (ICaptureDevice dev in devices)
{
  temp = dev.ToString();
  m = r.Match(temp);
  Console.WriteLine("{0}:{1}\n",j++,m.ToString());
}
Console.Write("輸入裝置號");
string input = Console.ReadLine();
int i = 0;
try
{
  i = Int32.Parse(input);
}
catch (Exception e)
{
  Console.WriteLine("非法輸入!"+e.Message);
  return;
}
if (devices.Count < 1 || i == -1)
{
  Console.WriteLine("變數非法!");
  return;
}
// 得到指定連線裝置
ICaptureDevice device = devices[i];

二、開啟連線

// 定義“包到達”事件
device.OnPacketArrival +=new SharpPcap.PacketArrivalEventHandler(device_OnPacketArrival);

// 開啟連線
int readTimeoutMilliseconds = 1000;
device.Open(DeviceMode.Promiscuous,readTimeoutMilliseconds);

三、設定過濾

// 設定僅獲取目標埠為1234的tcp包
string filter = "tcp dst port 1234";
device.Filter = filter;

四、開始獲取

// 開始無限期捕獲包
device.Capture();

五、包處理方法

private static void device_OnPacketArrival(object sender,CaptureEventArgs e)
{
  //獲取乙太網(Ethernet)的幀
  var ent = PacketDotNet.EthernetPacket.ParsePacket(LinkLayers.Ethernet,e.Packet.Data);
  //獲取ip包
  var ip = ent.PayloadPacket;
  //獲取tcp包
  var tcp = ip.PayloadPacket;
  //格式化tcp包,可直接讀取tcp包中的相應值
  var tcp_packet = new TcpPacket(new ByteArraySegment(tcp.Bytes));
  if (tcp != null)
  {
    DateTime time = e.Packet.Timeval.Date;
    if (tcp.PayloadData != null)
    {
      //根據需要,獲取tcp的data資料
      string str = BitConverter.ToString(tcp.PayloadData);
      /*
      *
      其他資料處理
      *
      */
    }
  }
}

六、技術有限,只做到這樣的程度

以上就是C# 實現抓包的例項程式碼的詳細內容,更多關於C# 抓包的資料請關注我們其它相關文章!