社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 2655阅读
  • 0回复

洞察融合多种传播方式的蠕虫病毒设计

级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
一个典型的蠕虫病毒有两个功能型部件:传播和破坏,流行的蠕虫病毒大都是利用操作系统或者应用程序的漏洞(以弱口令和溢出最为常见),但常常并不会对宿主机造成“致命”的破坏。这两个特点使蠕虫病毒比普通电脑病毒传播得更快,影响力更大。一般来说,单一的蠕虫病毒只针对某种特定的漏洞进行攻击,所以一旦这种漏洞得到大范围修补,病毒也就没有了生存空间。 ^C&+ ~+  
*5%*|>  
更新这种设计,我把传播部件拆分开来:把扫描、攻击和破坏脚本化,主程序则负责解析这些脚本。例如针对ftp弱口令进行扫描,我们可以定义如下脚本: vjViX<#(V  
puJ#w1!x`  
!/K8xD$  
code: :<#`_K~'  
        uid = iscript-0a21-2331-x #随机唯一编号 gM;}#>6  
        using tcp; ~$O1`IT  
        port 21; 09M;}4ev&7  
        send “user anonymous”; o7&4G$FX~  
        send crlf; Jeqxspn T  
        send “pass fake@nothing.com %>Xr5<$:&  
        send crlf; -U2mfW  
        if (find “200”) result ok; sPNfbCOz  
        next; 47 u@4"M  
      E(<LvMiCa  
+V v+K(lh$  
z*~YLT&  
解析了这段脚本后(我想这种脚本是很容易读懂的),我们再定义一系列的过程,把我们的蠕虫体upload上去,一次完整的传播动作就完成了。如果是溢出漏洞,为了简单起见我们可以采集远程溢出的数据包,然后修改ip地址等必要数据,再转发溢出数据包进行溢出(这种情况下要实现connect-back就不容易了,不过这些具体问题就待有心人去研究吧),例如: t0PQ~|H<KV  
_8K%`6!"Z  
9Z\z96O-  
code: kR.wOJ7'  
        using raw; *.y'(tj[  
        ip offset at 12; aI#4H+/  
        send “\x1a\xb2\xcc” …… #`tD1T{;  
        go)p%}s  
U6 82 Th  
?SY<~i<K-  
主程序在完成传播后留下一个后门,其他宿主机可以通过这个后门与本地的蠕虫病毒同步传播脚本,这样每次有新的漏洞产生,宿主机的传播方式可以很快地得到升级。我们当然不会仅满足于这样一个蠕虫程序,扫描/攻击脚本的传播过程也是需要仔细处理的。 71B3a  
nN`"z3o  
我们希望适应力(fitness)最强的脚本得到广泛的应用(看起来有点类似 蚁群算法 和 ga),所以我们要求得每个个体的fitness,当它和另一个体取得联系的时候就可以决定谁的传播脚本将取代另一个: w#PZu+  
ZofHi c  
#_Ea[q7v  
fitness = number of host infected / number of host scanned ^o<:;{  
但也不能仅凭fitness就修改传播脚本,我个人觉得一个合适的概率是75%,20%的机会保持各自的传播脚本,剩下的5%则交换脚本。这样在维持每种脚本都有一定生存空间的情况下使适应性最好的个体得到更多的传播机会,同时,一些在某种网络环境下适应性不强的脚本也有机会尝试不同的网络环境。
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水
描述
快速回复

您目前还是游客,请 登录注册
欢迎提供真实交流,考虑发帖者的感受
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八