病毒木马查杀实战第022篇:txt病毒研究
前言
反病毒爱好者们非常喜欢讨论的一个问题就是,现在什么样的病毒才算得上是主流,或者说什么样的病毒才是厉害的病毒呢?我们之前的课程所解说的都是Ring3层的病毒。所以有些朋友可能会觉得。那么Ring0层的病毒事实上才是最厉害的,也是病毒发展的主流;或者有朋友可能觉得,採取了五花八门的隐藏技术的病毒才是最难对付的。
诚然,大家的观点都非常有道理。病毒编写者往往也会用复杂高深的技术来武装自己的恶意程序,使其难以被发现难以被清除。那么是不是说Ring3层的病毒就没有“市场”了呢?我觉得不是。比方前段时间出现的“比特币敲竹杠”病毒。就是一个基于Ring3层的病毒,其特色就在于採用了一定的算法来加密目标计算机中的相应文件。而假设没有password,那么是不可能实现解密操作的。这就体现出了病毒作者的“创意”。说明即便没有高深的技术,但仅仅要有想法。那么Ring3层的病毒依然是非常可怕的。而我们这次所讨论的txt病毒,所走的也正是创意的路线。
一个奇怪的“txt”文件
在之前的课程中,我以前讨论过一种U盘病毒。当时在U盘中发现它的时候。我之所以没中圈套。正是由于我发现了它的.exe小尾巴:
图1
这也就说明,虽然它的图标是文件夹的图标,可是它本质上事实上就是一个可执行程序。利用图标的更换来将自己伪装成一个文件夹,这种手段还是比較古老的,也是非常easy被发现的。
相信大家通过那次的课程。也建立起了防范意识。
可是假设大家看到了一个这种文件。会作何感想?
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
图2
我相信,绝大部分的朋友是不会对这个文件起疑心的。会觉得这就是一个文本文档文件。会毫不犹豫地对其双击。可是双击执行后,那么也就中了陷阱,事实上这是一个经过伪装的Setup.exe,也就是我们之前讨论过的“熊猫烧香”病毒样本。
“txt病毒”原理
可能大家会有疑惑,为什么一个exe程序的“扩展名”会显示为txt呢?事实上,说它是一个“txt病毒”并不准确,严格来讲,它是一种混淆视听的手段。由于对于一个exe程序来说,我们不单单能够把它伪装成txt格式。还能够伪装成诸如jpg、doc、ppt等格式。事实上现原理就是採用了“反转字符串”的方法。
我们就拿“熊猫烧香”病毒样本为例:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
图3
首先能够使用Resource Hacker将该程序的图标改动为文本文档的图标:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
图4
然后我们将这个程序重命名为“readtxt.exe”,此时保持重命名的状态别确定。将光标移到“read”与“txt”的中间,单击鼠标右键。选择“插入Unicode控制字符”中的“RLO”:
图5
这个“RLO”是一个转义字符。仅仅要在一行字符前面加上它,就能够实现文本的反向排列。它是Unicode为了兼容某些文字的阅读习惯而设计的一个转义字符。当我们增加这个字符后。从而也就实现了图2中的效果。
那么利用这个原理,我们就能够实现非常多有创意的,而且颇具迷惑性的文件名称称。再将文件的图标改动为相应的假的后缀名的图标。那么我相信,即便是资深反病毒爱好者。也非常可能会落入陷阱的。
“RLO”与注冊表
事实上我们上面所讲的这个“RLO”的原理,还能够运用于其他的方面,比方注冊表:
图6
在上图中我们发现了两个名为“Microsoft”的项。而注冊表是不同意同名的项存在的。
事实上第二个“Microsoft”正是我利用转义字符原理生成的。
某些病毒程序就有可能利用这一点,来将自己伪装成正常的程序。这是须要大家格外留意的。
其他的字符陷阱
既然讲到了关于字符的陷阱。那么我这里再讲一个样例。
有些病毒为了实现站点的劫持。会把想要劫持的站点重定向到自己指定的地址。
为了实现这一目的。病毒作者通常的做法是改动Windows系统里位于%SystemRoot%\system32\drivers\etc文件夹下的hosts文件。
而病毒作者是不希望我们找到真实的hosts文件,以进行进一步的解析的,于是病毒作者能够将真实的hosts文件设置为隐藏,再伪造一个hosts文件出来。而伪造的方式,能够使用上述转义字符的方法,或者採用将原始的文件名称中的英文字符替换为其他的。easy造成混淆的字符。关于这个最为经典的样例就是 将“kernel32.dll”中“32”前面的“l”改为“1”,从而变成“kerne132.dll”,而后者正是一个恶意的动态链接库程序。
而详细到hosts这个样例。我们应当怎样达到混淆的效果呢?也非常简单,首先我们能够在“记事本”中输入“hosts”这几个字符,然后保存为Unicode的形式。接着使用十六进制编辑工具打开这个文本文档,查看其十六进制代码:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
图7
上图红框中的“6f 00”(注意这里是小端显示),也就是Unicode码的0x006f,表示的就是小写英文字母的“o”,那么这里我们将其改动为“3e 04”。也就是Unicode码的0x043e,它表示的是俄文字符的“o”:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
图8
保存后,再使用“记事本”打开,能够发现原来的“o”变成了一个怪怪的俄文字符:
图9
只是没关系。我们将上述字符复制粘贴。使其成为一个文件的名称。并复制到真实的hosts文件文件夹中:
图10
能够发现。此时出现了两个“hosts”文件,而事实上第二个是我们伪造的。从而也就达到了混淆的效果。
小结
假设我们光凭肉眼,是非常难阻止这类在字符上做手脚的病毒的,因此我在此也呼吁大家,一定要在计算机中安装杀毒软件,由于杀软并不会根据程序的名称进行杀毒,而是依靠病毒体内的特征码检測等方式来识别病毒的。
而对于我们伪装的“熊猫烧香”病毒样本。即便是我们之前所编写的简陋的主动防御系统,也是能够将其制止住的。这也就凸显了杀软的重要性。
病毒木马查杀实战第022篇:txt病毒研究的更多相关文章
- 病毒木马查杀实战第025篇:JS下载者脚本木马的分析与防御
前言 这次我与大家分享的是我所总结的关于JS下载者脚本木马的分析与防御技术.之所以要选择这样的一个题目,是因为在日常的病毒分析工作中,每天都会遇到这类病毒样本,少则几个,多则几十个(当然了,更多的样本 ...
- 病毒木马查杀实战第011篇:QQ盗号木马之专杀工具的编写
前言 由于我已经在<病毒木马查杀第004篇:熊猫烧香之专杀工具的编写>中编写了一个比较通用的专杀工具的框架,而这个框架对于本病毒来说,经过简单修改也是基本适用的,所以本文就不讨论那些重叠的 ...
- 病毒木马查杀实战第010篇:QQ盗号木马之十六进制代码分析
前言 按照我的个人习惯,在运用诸如IDA Pro与OllyDBG对病毒进行逆向分析之前,我都会利用一些自动化的工具,通过静态或动态的分析方法(参见<病毒木马查杀第008篇:熊猫烧香之病毒查杀总结 ...
- 病毒木马查杀实战第009篇:QQ盗号木马之手动查杀
前言 之前在<病毒木马查杀第002篇:熊猫烧香之手动查杀>中,我在不借助任何工具的情况下,基本实现了对于"熊猫烧香"病毒的查杀.但是毕竟"熊猫烧香" ...
- 病毒木马查杀实战第020篇:Ring3层主动防御之基本原理
前言 假设说我们的计算机中安装有杀毒软件,那么当我们有意或无意地下载了一个恶意程序后.杀软一般都会弹出一个对话框提示我们,下载的程序非常可能是恶意程序,建议删除之类的.或者杀软就不提示.直接删除了:或 ...
- 病毒木马查杀实战第015篇:U盘病毒之脱壳研究
前言 因为我们的终于目标是编写出针对于这次的U盘病毒的专杀工具.而通过上次的分析我们知道,病毒有可能在不同的计算机中会以不同的名称进行显示.假设真是如此,那么就有必要在此分析出病毒的命名规律等特征,然 ...
- 病毒木马查杀实战第017篇:U盘病毒之专杀工具的编写
前言 经过前几次的讨论,我们对于这次的U盘病毒已经有了一定的了解,那么这次我们就依据病毒的行为特征,来编写针对于这次U盘病毒的专杀工具. 专杀工具功能说明 因为这次是一个U盘病毒,所以我打算把这次的专 ...
- 病毒木马查杀实战第013篇:一个基于.NET的“敲竹杠”病毒研究
前言 恶意程序发展至今,其功能已经从最初的单纯破坏,不断发展为隐私的窥探,信息的盗取,乃至如今非常流行的"敲竹杠"病毒,用于勒索.可见随着时代的发展,病毒的作者们往往也是想利用自己 ...
- 病毒木马查杀实战第012篇:QQ盗号木马之逆向分析
前言 在本系列的文章中,对每一个病毒分析的最后一个部分,若无特殊情况,我都会采用逆向分析的手段来为读者彻底剖析目标病毒.但是之前的"熊猫烧香"病毒,我用了三篇文章的篇幅(每篇250 ...
随机推荐
- Selenium2+python自动化-gird分布式(转载)
本篇转自博客:上海-小T 原文地址:http://blog.csdn.net/real_tino/article/details/53467406 Selenium grid是用来分布式执行测试用例脚 ...
- 关于ros stage与navigation仿真总结5月16号
主要总结内容 在costmap里是怎么判断机器人和障碍物碰撞了 stage_ros包输入输出,stage是怎么回事 rviz 中footprint和stage中position怎么联系到一起 voxe ...
- svn泄漏敏感信息利用方式
之前仅知道svn权限配置不当,会导致敏感信息泄漏,但是一直不知道具体利用方式. 今天测试svn dig时抓包分析才知道: http://www.xxx.com/路径/.svn/text-base/文件 ...
- QTP自动化测试框架的基础知识
1. 什么是自动化测试框架? 假定你有一个活,需要构建许多自动化测试用例来测试这个应用程序.当你对这个应用程序完成自动化测试后,你对自己创建脚本应该有什么期望吗?你难道不想要- 脚本应该按照预期的来执 ...
- flutter 频道切换
https://github.com/flutter/flutter/wiki/Flutter-build-release-channels 频道说明页 https://flutter.dev/doc ...
- golang笔记:cookie
在同一个问题上栽了两次,以后碰到cookie出问题多半都是因为这个. Request.Cookie(name)取Cookie的时候,返回值只有name和value cookie.go cookies ...
- 数据排序 第三讲( 各种排序方法 结合noi题库1.10)
说了那么多种排序方法了,下面就来先做几个题吧 06:整数奇偶排序 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 给定10个整数的序列,要求对其重新排序.排序 ...
- ASP.NET Core 2.2 基础知识(十一) ASP.NET Core 模块
ASP.NET Core 应用与进程内的 HTTP 服务器实现一起运行.该服务器实现侦听 HTTP 请求,并在一系列请求功能被写到 HttpContext 时,将这些请求展现到应用中. ASP.NET ...
- Web应用程序指纹识别工具BlindElephant
Web应用程序指纹识别工具BlindElephant BlindElephant是一款Web应用程序指纹识别工具.该工具可以读取目标网站的特定静态文件,计算其对应的哈希值,然后和预先计算出的哈希值 ...
- luogu P3919 【模板】可持久化数组(可持久化线段树/平衡树)
As you see // luogu-judger-enable-o2 #include<cstdio> #include<cstring> #include<algo ...