通行证: 用户 密码 网站建设  下载中心 社区论坛 信息公告 my小屋
联系我们
设为首页
加入收藏

 

qq,asp,php,jsp,xml,sql,.net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | 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源码剖析》中的一句话——“源码之前,了无秘密。”如果你看完本文之后也有这样的感觉,那么我将感到不胜荣幸。

本新闻共3页,当前在第3页  1  2  3  


编辑: [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:黑客必知sql语句
下一篇:没有了
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
黑客必知sql语句 my123.com病毒改首页流氓大面积爆发 紧 nt下获得admin权限的四种方法
nt下使用匿名获得admin权限 如何正确手工剿灭qq广告弹出的木马程序 入侵检测(id)faq
对iis写权限的利用
最新更新 热点排行 推荐新闻
qq尾巴病毒的visual c++实现探讨
黑客必知sql语句
顶尖高手写的alexa作弊完全揭秘
nt下获得admin权限的四种方法
nt下使用匿名获得admin权限
qq尾巴病毒的visual c++实现探讨
黑客必知sql语句
防止黑客入侵adsl的一些技巧
与脚本病毒做斗争 几种常见的杀毒方法
恼人的dll后门完全清除秘诀
中了木马能够查的出来却杀不掉怎么办?
网吧频繁掉线(arp)与解决方法
危险无处不在 账号防盗防骗小经验
危险无处不在 账号防盗防骗小经验
遭遇另类无法删除病毒的处理办法
轻松玩转木马之菜鸟篇
nt下获得admin权限的四种方法
对iis写权限的利用
让你的密码成为黑客的“耻辱”
入侵检测(id)faq
破解qq密码如此简单 
dos教程 dos命令基础应用
最新永久免费网游年列表,免费3d网游
永久免费网游《刀ol》11月3日开放新服
低格、分区、高格的应对--dos命令应用
合并vcd片断、快速删除文件夹--dos命令
远程破解盗窃qq密码的各种方法
一劳永逸--批处理命令(一)
sql server安装文件挂起错误解决办法
三分钟让你的系统变处女:acronis tru
让你的密码成为黑客的“耻辱”
入侵中国某大型商业网站服务器全记录
防止黑客入侵adsl的一些技巧
猖狂的sxs.exe病毒处理方法
qq2006 beta3 飘云版 3.73 下载
qq挂太阳专家 v1.0.3  下载
q宠保姆(vc版) v2.15  下载
my123.com病毒改首页流氓大面积爆发 紧
用qq wlm inowshare随意共享文件
win2000下php服务器安装攻略
iis环境下安装php5手记全攻略
php5:session会话的使用和分析

设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights © 2004-2006 iyit.net all rights reserved.
网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息