时间:2021-05-20
工具: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"); //匹配连接的FriendlyNameMatch 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# 抓包的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.安装pythonnetpythonnet是一个强大的工具包,用于C#代码与python代码进行交互,不仅可以实现在C#中调用python,也可以实现在pyt
本文实例为大家分享了C#实现文件上传与下载的具体代码,供大家参考,具体内容如下C#实现文件上传代码:publicActionResultUpload(){//v
本文实例讲述了C#实现对字符串进行大小写切换的方法。分享给大家供大家参考。具体实现方法如下:C#代码如下:复制代码代码如下:publicclassProgram
本文实例讲述了fiddler抓包小技巧之自动保存抓包数据的实现方法。分享给大家供大家参考,具体如下:说起这个抓包啊,大家都不陌生。辣么,将自己抓获的数据保存下来
MacCharles抓包工具不过可惜的是,Fidder使用C#开发的,所以就不能在Mac上使用了,不过还有另外一个抓包神器,就是Charles,它是Java开发