C# 實(shí)現(xiàn)抓包的實(shí)例代碼
工具:SharpPcap 4.2.0
vs工程:控制臺(tái)應(yīng)用程序
關(guān)于C#抓包,我只找到SharpPcap 這個(gè)dll,相關(guān)的資料不多,而且都是挺老的,所以就順手記一下自己的代碼,給有同樣需求的人一個(gè)參考吧。
當(dāng)然,代碼可能存在問題,請見諒。
一、獲取連接設(shè)備
// 獲取連接列表
CaptureDeviceList devices = CaptureDeviceList.Instance;
// 無連接
if (devices.Count < 1)
{
Console.WriteLine("No devices were found on this machine");
return;
}
Console.WriteLine("\n以下為本機(jī)連接:");
Console.WriteLine("--------------\n");
int j=0;
string temp = "";
Regex r = new Regex("FriendlyName: .*\n"); //匹配連接的FriendlyName
Match m;
// 打印連接設(shè)備
foreach (ICaptureDevice dev in devices)
{
temp = dev.ToString();
m = r.Match(temp);
Console.WriteLine("{0}:{1}\n", j++, m.ToString());
}
Console.Write("輸入設(shè)備號");
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;
}
// 得到指定連接設(shè)備
ICaptureDevice device = devices[i];
二、打開連接
// 定義“包到達(dá)”事件 device.OnPacketArrival +=new SharpPcap.PacketArrivalEventHandler(device_OnPacketArrival); // 打開連接 int readTimeoutMilliseconds = 1000; device.Open(DeviceMode.Promiscuous, readTimeoutMilliseconds);
三、設(shè)置過濾
// 設(shè)置僅獲取目標(biāo)端口為1234的tcp包 string filter = "tcp dst port 1234"; device.Filter = filter;
四、開始獲取
// 開始無限期捕獲包 device.Capture();
五、包處理方法
private static void device_OnPacketArrival(object sender, CaptureEventArgs e)
{
//獲取以太網(wǎng)(Ethernet)的幀
var ent = PacketDotNet.EthernetPacket.ParsePacket(LinkLayers.Ethernet, e.Packet.Data);
//獲取ip包
var ip = ent.PayloadPacket;
//獲取tcp包
var tcp = ip.PayloadPacket;
//格式化tcp包,可直接讀取tcp包中的相應(yīng)值
var tcp_packet = new TcpPacket(new ByteArraySegment(tcp.Bytes));
if (tcp != null)
{
DateTime time = e.Packet.Timeval.Date;
if (tcp.PayloadData != null)
{
//根據(jù)需要,獲取tcp的data數(shù)據(jù)
string str = BitConverter.ToString(tcp.PayloadData);
/*
*
其他數(shù)據(jù)處理
*
*/
}
}
}
六、技術(shù)有限,只做到這樣的程度
以上就是C# 實(shí)現(xiàn)抓包的實(shí)例代碼的詳細(xì)內(nèi)容,更多關(guān)于C# 抓包的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C# 數(shù)組刪除元素的實(shí)現(xiàn)示例
本文主要介紹了C# 數(shù)組刪除元素的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
WPF實(shí)現(xiàn)動(dòng)畫效果(一)之基本概念
這篇文章介紹了WPF實(shí)現(xiàn)動(dòng)畫效果之基本概念,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
C#事件中的兩個(gè)參數(shù)詳解(object sender,EventArgs e)
這篇文章主要介紹了C#事件中的兩個(gè)參數(shù)詳解(object sender,EventArgs e),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
C#動(dòng)態(tài)調(diào)整數(shù)組大小的方法
這篇文章主要介紹了C#動(dòng)態(tài)調(diào)整數(shù)組大小的方法,涉及C#中靜態(tài)方法CreateInstance的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04

