| 网站建设 下载中心 社区论坛 信息公告 my小屋 |
![]() |
联系我们 设为首页 加入收藏 |
|
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿 论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图 专题 | 应用软件 | 聊天通讯 | q q 专栏 | 建站经验 | 在线工具 | 站长club | 注 册 表 | 旧版 社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 韩国素材 | 素材图库 | 广告服务 | 服务 |
| 新版上线![旧版] | |||||
注:打开慢时请稍等
qq尾巴病毒的visual c++实现探讨http://www.iyit.net 日期:2006-11-21 13:29:48 来源: 点击: |
到此为止,以上所有的代码都位于一个hook.dll的动态链接库之中,关于dll我就不多介绍了,请查阅msdn上的相关资料和本文的配套源代码。 dll之中已经做好了所有重要的工作(事实上这部分工作也只能由dll来完成,这是由windows虚拟内存机制决定的),我们只需要在exe之中调用导出的sethook函数就可以了。那么,sethook的参数如何获得呢?请看以下代码: // 感谢好友hottey的查找代码,省去了我使用spy++的麻烦hwnd hsend;g_hqq = null;sethook(null);do{ g_hqq = findwindowex(null, g_hqq, "#32770", null); hsend = findwindowex(g_hqq, null, "button", "发送(&s)");} while(g_hqq != null && hsend == null);if (g_hqq != null)sethook(g_hqq); 这段代码中的do-while循环就是用来查找“发送消息”的窗口的,qq窗口的保密性越来越强了,窗口一层套一层,找起来十分不便,所以在此感谢好友hottey的《qq消息炸弹随想》一文省去了我反复使用spy++的麻烦。我所做的,只是把他文中的delphi代码翻译成了c代码。 dll的共享数据段 如果你对dll不甚了解,那么在你读到我的配套源代码之后,肯定会对下面这一段代码有些疑问: // 定义共享数据段#pragma data_seg("shared")hhook g_hproc = null; // 窗口过程钩子句柄hhook g_hkey = null; // 键盘钩子句柄hwnd g_hrich = null; // 文本框句柄#pragma data_seg()#pragma comment(linker, "/section:shared,rws") 这定义了一段共享的数据段,是的,因为我的注释已经写得很清楚了,那么共享数据段起到了什么作用呢?在回答这个问题之前,我请你把代码中以#开头的预处理指令注释掉然后重新编译这个dll并运行,你会发现什么? 是的,添加尾巴失败! 好了,我来解释一下这个问题。我们的这个仿真程序的exe、dll以及qq的主程序事实上是下面这样一种关系: 这个dll需要将一个实例映射到exe的地址空间之中以供其调用,还需要将另一个实例映射到qq的地址空间之中来完成挂接钩子的工作。也就是说,当钩子挂接完毕之后,整个系统的模块中,有两个dll实例的存在!此dll非彼dll也,所以它们之间是没有任何联系的。拿全局变量g_hrich来说,图中左边的dll通过exe的传入获得了文本框的句柄,然而如果没有共享段的话,那么右边的dll中,g_hrich仍然是null。共享段于此的意义也就体现出来了,就是为了保证exe、dll、qq三者之间的联系。这一点,和c++中static的成员变量有些相似。 在钩子挂接成功之后,你可以通过一些有模块查看功能的进程管理器看一看,就会发现hook.dll也位于qq.exe的模块之中。 最后一些要说的 1、我是前说过,在2003年的1月份我就碰到了这种病毒,至今我还很清楚地记得那个病毒exe只有16kb大小,所以从病毒本身存在的性质来说,这个东西应该是用win32asm来写会更实用一些。 2、那个病毒我曾经是手杀的——用了一个进程查看工具就杀掉了。但是现在的“qq尾巴”增加了复活功能——在exe被杀掉后,dll会将其唤醒。我曾经用我的进程查看工具分析过,发现系统中几乎所有的进程都被病毒的dll挂住了。这一技术是利用createremotethread在所有的进程上各插入了一个额外的复活线程,真可谓是一石二鸟——保证exe永远运行,同时这个正在使用中的dll是无法被删除的。这一技术我也已经实现了,但是稳定性方面远不及病毒本身做得优秀,故在此也就不将其写出了,有兴趣的朋友可以参考jeffrey richter《windows核心编程》的相关章节。 3、走笔至此想起了侯捷老师《stl源码剖析》中的一句话——“源码之前,了无秘密。”如果你看完本文之后也有这样的感觉,那么我将感到不胜荣幸。 编辑: [发送给好友] [打印本页] [关闭窗口] [返回顶部] 上一篇:黑客必知sql语句 下一篇:没有了 转载请注明来源:www.iyit.net 特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。 |
| 相关文章 | |||||||||||
|
| 设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接 |
| |||||||