QQ蠕虫的行为检测方法

QQ蠕虫是一种利用QQ等腾讯公司相关产品进行传播的一种特殊蠕虫,该蠕虫的基本原理是利用了QQ帐户的快速登录机制,只要当前系统中有一个QQ帐户成功登录,就可以通过后台接口实现该帐户相关应用的快速登录而不需要再次输入帐户密码。登录后蠕虫可以访问QQ应用的各种网络接口,例如:通过接口实现加QQ好友、加入QQ群、发消息、发日志、发微博、上传群共享文件等操作,且完全不需要用户同意。借用这种技术,QQ蠕虫可以实现非常快速的传播。这种蠕虫诞生于QQ体系之上,其影响和传播主要集中在国内地区,因此国外品牌的杀软对这类蠕虫识别和支持非常有限,国内的杀软品牌对该蠕虫检测也不是特别理想,从而导致了该QQ蠕虫的传播更加快速,影响范围更广。 

[[114765]]

基于以上信息,利用WinPcap技术抓取网络数据包,对HTTP POST包进行分析,过滤出对域名qq.com访问的数据包,但是由于WinPcap考虑到很多数据结构需要自己封装且第一阶段比赛时间结束只有几天,所以决定使用sharpPcap+C# 代替常用的WinPcap+VC来捕获数据包。

实现基本思路

(1)经典的HTTP请求方式:

  1. GET /somedir/page.html HTTP/1.1  
  2. Host:  www.someschool.edu  
  3. Connection: close  
  4. User-agent: Mozilla/4.0  
  5. Accept-language: fr 

(2)我们注意到HTTP请求报文中的第一行是以GET打头的,它实际上是HTTP请求的一种方法,类似的还有POST、HEAD等等。一般熟知的大概就是GET和POST。

(3)利用这个我们就可以用 sharpPcap 技术抓取网络数据包,在数据包中判断TCP数据报文里是否保存了HTTP数据。如果有HTTP数据且是请求报文,就获得了HTTP的 GET、POST 请求数据后进行解析,数据的解析可以通过Content-Type分析数据格式,并按照相应的解析方式进行解码,解码过程中还有对于中文字符的处理等等。

部分功能实现

基于sharpPcap,C#写的抓包程序源代码

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using SharpPcap;  
  6. namespace SharpPcapTest  
  7. {  
  8. class Program  
  9. {  
  10. static void Main(string[] args)  
  11. {  
  12. PacketArrivalForm packArrivalForm = new PacketArrivalForm();  
  13. packArrivalForm.ShowDialog();  
  14. FileOperate fileOperate = new FileOperate();  
  15. string ver = SharpPcap.Version.VersionString;  
  16. Console.WriteLine("SharpPcap {0}, Example1.IfList.cs", ver);  
  17. String strTemp = "SharpPcap" + ver + "\n";  
  18. fileOperate.wtiteToTxtFile(@".\123.txt", strTemp);  
  19. // Retrieve the device list  
  20. var devices = LivePcapDeviceList.Instance;  
  21. // If no devices were found print an error  
  22. if (devices.Count < 1)  
  23. {  
  24. Console.WriteLine("No devices were found on this machine");  
  25. return;  
  26. }  
  27. Console.WriteLine("\nThe following devices are available on this machine:");  
  28. Console.WriteLine("----------------------------------------------------\n");  
  29. /* Scan the list printing every entry */  
  30. /*获取驱动列表*/  
  31. foreach (var dev in devices)  
  32. {  
  33. //Console.WriteLine("{0}\n", dev.ToString());  
  34. fileOperate.wtiteToTxtFile(@".\123.txt", dev.ToString());  
  35. strTemp += dev.ToString();  
  36. }  
  37. //在对话框中显示相关的设备信息  
  38. ShowForm showForm = new ShowForm();  
  39. showForm.setRichTextBoxStr(strTemp);  
  40. showForm.ShowDialog();  
  41. /*接收数据包时间等各种数据*/  
  42. int  i = int.Parse(Console.ReadLine());  
  43. LivePcapDevice device = devices[i];  
  44. // Register our handler function to the 'packet arrival' event  
  45. device.OnPacketArrival += new PacketArrivalEventHandler(device_OnPacketArrival);  
  46. // Open the device for capturing  
  47. int readTimeoutMilliseconds = 1000;  
  48. device.Open(DeviceMode.Promiscuous, readTimeoutMilliseconds);  
  49. Console.WriteLine();  
  50. Console.WriteLine("-- Listening on {0}, hit 'Enter' to stop...",device.Description);  
  51. strTemp = "Hour\tMinute\tSecond\tMillisecond\tlen\n";  
  52. fileOperate.wtiteToTxtFile(@".\data.txt", strTemp);  
  53. // Start the capturing process  
  54. device.StartCapture();  
  55. // Wait for 'Enter' from the user.  
  56. Console.ReadLine();  
  57. // Stop the capturing process  
  58. device.StopCapture();  
  59. Console.WriteLine("-- Capture stopped.");  
  60. // Print out the device statistics  
  61. Console.WriteLine(device.Statistics().ToString());  
  62. fileOperate.wtiteToTxtFile(@".\data.txt", device.Statistics().ToString());  
  63. Console.Write("Hit 'Enter' to exit...");  
  64. Console.ReadLine();  
  65. }  
  66. private static void device_OnPacketArrival(object sender, CaptureEventArgs e)  
  67.    
  68. {  
  69. FileOperate fileOperate = new FileOperate();  
  70. var time = e.Packet.Timeval.Date;  
  71. var len = e.Packet.Data.Length;  
  72. Console.WriteLine("{0}:{1}:{2},{3} Len={4}",time.Hour, time.Minute, time.Second, time.Millisecond, len);  
  73. string strTemp = time.Hour.ToString() + "\t" + time.Minute.ToString() + "\t" +  time.Second.ToString() + "\t" + time.Millisecond.ToString() + "\t\t" +  len.ToString() + "\n";  
  74. Console.WriteLine(e.Packet.ToString());  
  75. strTemp += "\n" + e.Packet.ToString() + "\n";  
  76. fileOperate.wtiteToTxtFile(@".\data.txt", strTemp);  
  77. }  
  78. }  

 设备信息截图:

 

获取数据包数据截图:

完整程序下载:http://pan.baidu.com/s/1i3vEX1r

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/136058.html<

(0)
运维的头像运维
上一篇2025-03-01 22:03
下一篇 2025-03-01 22:04

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注