本文是利用SharpPcap实现网络包的捕获的小例子,实现了端口监控,数据包捕获等功能,主要用于学习分享。

什么是SharpPcap?

SharpPcap 是一个.NET 环境下的网络包捕获框架,基于著名的 pcap/WinPcap 库开发。提供了捕获、注入、分析和构建的功能,适用于 C# 和 VB NET 开发语言。

SharpPcap有两部分组成:1> SharpPcap.dll 负责数据的捕获  2> PacketDotNet.dll负责数据包的解析

思路:

  1. 通过进程名字获取对应的端口号。
  2. SharpPcap获取对应的数据包,通过解析数据包过滤相关的端口。

涉及知识点:

  • Process 获取相关进程信息。
  • netstat命令:netstat -ano|find "3844" 获取进程对应的端口
  • SharpPcap相关信息:
    • 通过CaptureDeviceList的静态方法获取设备列表。
    • 通过OnPacketArrival事件接收数据包。
    • 通过PacketDotNet来解析数据包

效果图下:

SharpPcap核心代码:

  1. /// <summary>
  2. /// 开始捕捉
  3. /// </summary>
  4. /// <param name="sender"></param>
  5. /// <param name="e"></param>
  6. private void btnStart_Click(object sender, EventArgs e)
  7. {
  8. if (this.combDevice.SelectedIndex > -)
  9. {
  10. StartCapture(this.combDevice.SelectedIndex);
  11. this.btnStart.Enabled = false;
  12. this.btnStop.Enabled = true;
  13. }
  14. else {
  15. MessageBox.Show(this,"请选择一个设备","提示",MessageBoxButtons.OK);
  16. }
  17. }
  18.  
  19. /// <summary>
  20. /// 停止捕捉
  21. /// </summary>
  22. /// <param name="sender"></param>
  23. /// <param name="e"></param>
  24. private void btnStop_Click(object sender, EventArgs e)
  25. {
  26. Shutdown();
  27. this.btnStop.Enabled = false;
  28. this.btnStart.Enabled = true;
  29. }
  30.  
  31. private void StartCapture(int itemIndex)
  32. {
  33. packetCount = ;
  34. device = CaptureDeviceList.Instance[itemIndex];
  35. packetStrings = new Queue<PacketWrapper>();
  36. bs = new BindingSource();
  37. dgvData.DataSource = bs;
  38. LastStatisticsOutput = DateTime.Now;
  39.  
  40. // start the background thread
  41. backgroundThreadStop = false;
  42. backgroundThread = new Thread(BackgroundThread);
  43. backgroundThread.Start();
  44.  
  45. // setup background capture
  46. device.OnPacketArrival += new PacketArrivalEventHandler(device_OnPacketArrival);
  47. device.OnCaptureStopped += new CaptureStoppedEventHandler(device_OnCaptureStopped);
  48. device.Open();
  49.  
  50. // tcpdump filter to capture only TCP/IP packets
  51. string filter = "ip and tcp";
  52. device.Filter = filter;
  53.  
  54. // force an initial statistics update
  55. captureStatistics = device.Statistics;
  56. UpdateCaptureStatistics();
  57.  
  58. // start the background capture
  59. device.StartCapture();
  60.  
  61. btnStop.Enabled = true;
  62. }
  63.  
  64. /// <summary>
  65. /// 设备接收事件
  66. /// </summary>
  67. /// <param name="sender"></param>
  68. /// <param name="e"></param>
  69. private void device_OnPacketArrival(object sender, CaptureEventArgs e)
  70. {
  71. // print out periodic statistics about this device
  72. var Now = DateTime.Now;
  73. var interval = Now - LastStatisticsOutput;
  74. if (interval > new TimeSpan(, , ))
  75. {
  76. Console.WriteLine("device_OnPacketArrival: " + e.Device.Statistics);
  77. captureStatistics = e.Device.Statistics;
  78. statisticsUiNeedsUpdate = true;
  79. LastStatisticsOutput = Now;
  80. }
  81.  
  82. lock (QueueLock)
  83. {
  84. PacketQueue.Add(e.Packet);
  85. }
  86. }
  87.  
  88. /// <summary>
  89. /// 设备停止事件
  90. /// </summary>
  91. /// <param name="sender"></param>
  92. /// <param name="status"></param>
  93. private void device_OnCaptureStopped(object sender, CaptureStoppedEventStatus status)
  94. {
  95. if (status != CaptureStoppedEventStatus.CompletedWithoutError)
  96. {
  97. MessageBox.Show("Error stopping capture", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  98. }
  99. }
  100.  
  101. private void UpdateCaptureStatistics()
  102. {
  103. tlblStatistic.Text = string.Format("接收包: {0}, 丢弃包: {1}, 接口丢弃包: {2}", captureStatistics.ReceivedPackets,captureStatistics.DroppedPackets, captureStatistics.InterfaceDroppedPackets);
  104. }

关于SharpPcap手册

源码下载

C# 利用SharpPcap实现网络包捕获嗅探的更多相关文章

  1. SharpPcap网络包捕获框架的使用--实例代码在vs2005调试通过

    转自:http://hi.baidu.com/boyxgb/blog/item/89ac86fbdff5f82c4e4aea2e.html 由于项目的需要,要从终端与服务器的通讯数据中获取终端硬件状态 ...

  2. Android利用Fiddler进行网络数据抓包,手机抓包工具汇总

    Fiddler抓包工具 Fiddler抓包工具很好用的,它可以干嘛用呢,举个简单例子,当你浏览网页时,网页中有段视频非常好,但网站又不提供下载,用迅雷下载你又找不到下载地址,这个时候,Fiddler抓 ...

  3. Linux 中的网络数据包捕获

    Linux 中的网络数据包捕获 Ashish Chaurasia, 工程师 简介: 本教程介绍了捕获和操纵数据包的不同机制.安全应用程序,如 VPN.防火墙和嗅探器,以及网络应用程序,如路由程序,都依 ...

  4. Android利用Fiddler进行网络数据抓包,手机抓包工具汇总,使用mono运行filddler

    Fiddler抓包工具 Fiddler抓包工具很好用的,它可以干嘛用呢,举个简单例子,当你浏览网页时,网页中有段视频非常好,但网站又不提供下载,用迅雷下载你又找不到下载地址,这个时候,Fiddler抓 ...

  5. Android利用Fiddler进行网络数据抓包

    最新最准确内容建议直接访问原文:Android利用Fiddler进行网络数据抓包 主要介绍Android及IPhone手机上如何进行网络数据抓包,比如我们想抓某个应用(微博.微信.墨迹天气)的网络通信 ...

  6. Android利用Fiddler进行网络数据抓包【怎么跟踪微信请求】

    主要介绍Android及IPhone手机上如何利用Fiddler进行网络数据抓包,比如我们想抓某个应用(微博.微信.墨迹天气)的网络通信请求就可以利用这个方法. Mac 下请使用 Charles 代替 ...

  7. 利用libpcap分析网络上的数据包(入门级)

    本文可任意转载,但请保留作者及出处作者:rainfish出处:http://blog.csdn.net/bat603/经过几天的突击,终于明白了怎样在局域网内抓包,这可是我多年来的梦想.首先说说我的学 ...

  8. [转] Android利用Fiddler进行网络数据抓包

    主要介绍Android及IPhone手机上如何利用Fiddler进行网络数据抓包,比如我们想抓某个应用(微博.微信.墨迹天气)的网络通信请求就可以利用这个方法. Mac 下请使用 Charles 代替 ...

  9. MX2怎样利用Fiddler进行网络数据抓包

    首先须要保证PC与手机在同一局域网内或有独立公网IP, 下面以在同一局域网为例(保证手机能訪问到这台PC机器): 1. PC端配置 1). 安装Fiddler 2). 开启Fiddler下面功能:   ...

随机推荐

  1. 朴素贝叶斯算法简介及python代码实现分析

    概念: 贝叶斯定理:贝叶斯理论是以18世纪的一位神学家托马斯.贝叶斯(Thomas Bayes)命名.通常,事件A在事件B(发生)的条件下的概率,与事件B在事件A(发生)的条件下的概率是不一样的:然而 ...

  2. Scala - Tips

    1- 运行scala命令,提示报错 问题现象: 在Windows7系统中安装scala后(直接安装MSI包,或者解压zip包添加环境变量的方式),执行scala命令报错,但可以执行scala -ver ...

  3. Robot Framework - 建立本地测试环境

    注意:本文内容是以“在Window7系统中安装本地RobotFrmamework自动化测试环境”为例. Robot Framework简介 HomePage:http://robotframework ...

  4. 序列化与反序列化之JSON

    在不同编程语言之间传递对象,须把对象序列化为标准格式,比如XML 但更好的方法是序列化为JSON,因为JSON表示出来就是一个字符串,可被所有语言读取,也可方便地存储到磁盘或者通过网络传输 JSON不 ...

  5. React 实现一个时钟

    最终效果 其实主要难点在于最左边的小时钟 指针的实现方式很简单,就是通过绝对定位将指针移到中间,然后以下边中间的位置为圆心旋转即可.代码如下: <!DOCTYPE html> <ht ...

  6. rest-framework之权限组件

    权限 权限 作用 : 校验用户是否有权限访问 检测权限肯定是在用户认证通过之后,所有可以直接在request中取出用户做判断 先定义一个类,继承 BasePermission. from rest_f ...

  7. springboot Aop 统一处理Web请求日志

    1.增加依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...

  8. 介绍 JSON(摘自网络)

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Programming Lan ...

  9. CSS从零开始(1)--CSS基础语法

    1.CSS语法 CSS规则有两个主要部分构成:选择器,以及一条或多条说明. 例如:selector{declaration1;declaration2;declaration3;......;} 注: ...

  10. docker使用ssh远程连接容器(没钱买服务器又不想安装虚拟机患者必备)

    突然有需求,需要使用go语言写个ssh终端连接功能,这时候手上又没有服务器,虚拟机也没有,正好使用docker搞起来 docker容器开启sshd服务,模拟服务器 我们知道docker是可以用exec ...