C# .NET 使用第三方库SharpPcap进行抓包示例

        本文主要讲述使用C#库进行抓包的示例代码,其本人在网上搜索了很久,找到了很多关于使用SharpPcap库的示例,但均会报错,通过VS种 '管理NuGet程序包'安装好了SharpPcap及其依赖,但会因为版本及其内部代码变更而导致程序报错。后面我会将完整代码上传以供参考学习(如下载我所编写代码,可以保证其库文件及依赖版本正确,visual studio版本为Microsoft Visual Studio Community 2022 (64 位) - Current版本 17.9.1)。

代码部分

1.此为初始化及开始抓包部分示例

private void MonitorBtn_Click(object sender, EventArgs e)
{
    var devices = CaptureDeviceList.Instance; //初始化
    //devices[0].
    foreach (var dev in devices)
    {
        Console.WriteLine("{0}\n", dev.ToString()); // 选择网卡
    }
        

    device = LibPcapLiveDeviceList.Instance[1];
    if (MonitorBtn.Text == "开始监听")
    {
        device.Open(DeviceModes.Promiscuous);
        device.OnPacketArrival += Device_OnPacketArrival;
        device.StartCapture();
        MonitorAllBtn.Enabled = true;

        MonitorBtn.Text = "关闭监听";
    }
    else if(MonitorBtn.Text == "关闭监听")
    {
        device.Close();

        MonitorBtn.Text = "开始监听";
    }

}

2.内容部分

 public void Device_OnPacketArrival(object sender, PacketCapture e)
 {
     rawPacket = e.GetPacket();

     //--------------------------------------------------------------------------
     var packet = PacketDotNet.Packet.ParsePacket(rawPacket.LinkLayerType, rawPacket.Data);
     var tcpPacket = packet.Extract<PacketDotNet.TcpPacket>();// 如果是TCP协议的数据包,则提取TcpPacket对象,否则为null
     var udpPacket = packet.Extract<PacketDotNet.UdpPacket>(); // 如果是UDP协议的数据包,则提取UdpPacket对象,否则为null


     //提取端口号
     if (tcpPacket != null)
     {
         ipPacket = (IPPacket)tcpPacket.ParentPacket;

         var sourcePort = tcpPacket.SourcePort; // 源端口号(TCP协议)  
         destinationPort = tcpPacket.DestinationPort; // 目标端口号(TCP协议)  

         // 提取校验和
         var checksum = tcpPacket.Checksum;
         //Console.WriteLine($"源端口: {sourcePort}, 目标端口: {destinationPort}");
         //Console.WriteLine("校验和: " + checksum);


         if (tcpPacket.PayloadData != null)
         {
             // 提取载荷
             payload = Encoding.ASCII.GetString(tcpPacket.PayloadData);
         }
         else
         {
             payload = "无可用有效载荷";
         }

     }
     else if (udpPacket != null)
     {
         ipPacket = (IPPacket)udpPacket.ParentPacket;

         var sourcePort = udpPacket.SourcePort; // 源端口号(UDP协议)  
          destinationPort = udpPacket.DestinationPort; // 目标端口号(UDP协议)  

         // 提取校验和
         var checksum = udpPacket.Checksum;
         //Console.WriteLine($"源端口: {sourcePort}, 目标端口: {destinationPort}");
         //Console.WriteLine("校验和: " + checksum);
     }

     if (ipPacket != null)
     {
         // 提取IP地址
         var sourceIpAddress = ipPacket.SourceAddress;
         var destinationIpAddress = ipPacket.DestinationAddress;

         // 提取协议类型
         var protocolType = ipPacket.Protocol;

         // 提取TTL
         var ttl = ipPacket.TimeToLive;


         // 提取MAC地址
         var ethernetPacket = packet.Extract<EthernetPacket>();
         var sourceMacAddress = ethernetPacket.SourceHardwareAddress;
         var destinationMacAddress = ethernetPacket.DestinationHardwareAddress;

         // 提取时间戳
         var timestamp = rawPacket.Timeval.Date;

         // 提取传输数据
         var data = rawPacket.Data;
    }

//此为将抓取的数据包中的内容转换为ASCII码形式
    string sum1111 = "";
if (tcpPacket != null && tcpPacket.PayloadData != null)
{
    for (int i = 1; i <= tcpPacket.PayloadData.Length; i++)
    {
        if (tcpPacket.PayloadData[i - 1] >= 33 && tcpPacket.PayloadData[i - 1] <= 126)
        {
            sum1111 += Encoding.ASCII.GetString(new byte[1] { tcpPacket.PayloadData[i - 1] });
        }
        else
        {
            //sum1111 += tcpPacket.PayloadData[i - 1].ToString();
            sum1111 += ".";
        }
    }
}
else if (udpPacket != null && udpPacket.PayloadData != null)
{
    for (int i = 1; i <= udpPacket.PayloadData.Length; i++)
    {
        if ((udpPacket.PayloadData[i - 1] >= 33 && udpPacket.PayloadData[i - 1] <= 126))
        {
            sum1111 += Encoding.ASCII.GetString(new byte[1] { udpPacket.PayloadData[i - 1] });
        }
        else
        {
            //sum1111 += tcpPacket.PayloadData[i - 1].ToString();
            sum1111 += ".";
        }
    }

if (FindSubstring(sum1111, "http") != null || FindSubstring(sum1111, "www") != null || FindSubstring(sum1111, "com") != null || FindSubstring(sum1111, "cn") != null)
{
    if(DataListGridView.Rows.Count != 0)
    {
        if(DataListGridView.CurrentRow.Index != -1)
        {
            rowsSele = DataListGridView.CurrentRow.Index;
            if (sourceIpAddress.ToString() == DataListGridView.Rows[DataListGridView.CurrentRow.Index].Cells[1].Value.ToString())
            {
                this.Invoke(new Action(() =>
                {
                    textBox1.Text += "源IP地址: " + sourceIpAddress + "\r\n";
                    textBox1.Text += "目标IP地址: " + destinationIpAddress + "\r\n";
                    textBox1.Text += "目标MAC地址: " + destinationMacAddress + "\r\n";
                    textBox1.Text += "目标端口: " + destinationPort.ToString() + "\r\n";
                    textBox1.Text += "时间戳: " + timestamp + "\r\n";
                    textBox1.Text += "传输数据: " + sum1111 + "\r\n";
                    textBox1.Text += "----------------------------------------------------------" + "\r\n";
                    textBox1.Text += "\r\n";

                    textBox1.SelectionStart = textBox1.Text.Length;
                    textBox1.ScrollToCaret();
                }));
            }
        }
    }
}
}

此为我所编写源代码    后面可以下载我所上传资源直接查看程序会更加的清晰明了

资源下载链接:https://download.csdn.net/download/m0_54169323/88881319?spm=1001.2014.3001.5501

  • 20
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SharpPcap是一个开源的网络抓包库,它提供了在Windows平台上进行网络数据包捕获和处理的功能。为了使用SharpPcap进行发包,我们需要使用它的发送功能。下面是一个使用SharpPcap进行发包的基本示例。 首先,我们需要创建一个SharpPcap的PacketCommunicator对象,并指定要发送数据包的网络接口。例如: ``` PacketCommunicator communicator = new SharpPcap.WinPcap.WinPcapDevice("eth0").Open(); ``` 然后,我们需要创建一个要发送的数据包。我们可以使用SharpPcap的PacketDotNet库来构建数据包。例如,我们可以创建一个简单的以太网数据包: ``` EthernetPacket packet = new EthernetPacket( EthernetPacket.GetMacByNetworkInterface(communicator.Device), PhysicalAddress.Parse("00:00:00:00:00:00"), EthernetPacketType.IpV4); ``` 接下来,我们可以设置数据包的各个字段,例如源IP地址、目的IP地址、源端口、目标端口等。以太网数据包的源和目标MAC地址已经在上面的代码中设置好了。 最后,我们可以使用PacketCommunicator的SendPacket方法来发送数据包: ``` communicator.SendPacket(packet); ``` 这样就可以通过SharpPcap发送数据包了。需要注意的是,为了使用SharpPcap进行发包,你需要以管理员权限运行你的应用程序。 总结一下,通过SharpPcap进行发包可以分为三个步骤:创建PacketCommunicator对象并指定网络接口、创建要发送的数据包、使用PacketCommunicator发送数据包。希望这个简单的示例可以帮助你理解如何使用SharpPcap进行发包操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值