2018-2019-2 20165236 《网络对抗技术》Exp4 恶意代码分析
2018-2019-2 20165236 《网络对抗技术》Exp4 恶意代码分析
一、1.实践目标
1.1是监控你自己系统的运行状态,看有没有可疑的程序在运行;
1.2是分析一个恶意软件,就分析Exp2或Exp3中生成后门软件;分析工具尽量使用原生指令或sysinternals,systracer套件;
1.3假定将来工作中你觉得自己的主机有问题,就可以用实验中的这个思路,先整个系统监控看能不能找到可疑对象,
再对可疑对象进行进一步分析,好确认其具体的行为与性质。
2.实践内容(3.5分)
2.1系统运行监控(2分)
(1)使用如计划任务,每隔一分钟记录自己的电脑有哪些程序在联网,连接的外部IP是哪里。运行一段时间并分析该文件,
综述一下分析结果。目标就是找出所有连网的程序,连了哪里,大约干了什么(不抓包的情况下只能猜),你觉得它这么干合适不。如果想进一步分析的,可以有针对性的抓包。
(2)安装配置sysinternals里的sysmon工具,设置合理的配置文件,监控自己主机的重点事可疑行为。
实际日志的分析还需要发挥下自己的创造力,结合以前学过的知识如linux的文本处理指令等进行。分析的难点在于从大量数据中理出规律、找出问题。这都依赖对结果过滤、统计、分类等进一步处理,这就得大家会什么用什么了。
2.2恶意软件分析(1.5分)
分析该软件在(1)启动回连,(2)安装到目标机(3)及其他任意操作时(如进程迁移或抓屏,重要是你感兴趣)。该后门软件
(3)读取、添加、删除了哪些注册表项
(4)读取、添加、删除了哪些文件
(5)连接了哪些外部IP,传输了什么数据(抓包分析)
二、实验步骤
任务一 系统运行监控
1、使用如计划任务,每隔一分钟记录自己的电脑有哪些程序在联网,连接的外部IP是哪里。运行一段时间并分析该文件,综述一下分析结果。目标就是找出所有连网的程序,连了哪里,大约干了什么(不抓包的情况下只能猜),你觉得它这么干合适不。如果想进一步分析的,可以有针对性的抓包。
输入:schtasks /create /TN netstat5236 /sc MINUTE /MO 5 /TR "cmd /c netstat -bn > c:\netstat5236.txt"命令,创建计划任务netstat5236,

2、在C盘中创建一个netstat5236.bat脚本文件,写入以下内容:
date /t >> c:\netstat5236.txt
time /t >> c:\netstat5236.txt
netstat -bn >> c:\netstat5236.txt
我是先在桌面上创建txt文本文件,然后修改文件名保存到C盘中:

3、在开始中,打开任务计划程序,可以看到创建的任务netstat5236,

4、打开这个任务,点击操作并编辑,将“程序或脚本”改为我们创建的netstat5236.bat批处理文件,然后确定,如图所示:


5、在属性中“常规”一栏最下面勾选“使用最高权限运行”,防止程序不会自动运行:

6、在属性中“条件”选项中“电源”栏中,取消勾选“只有计算机使用交流电源才启动此任务”,防止电脑断电任务就停止:

7、输入schtasks /create /TN 20165236netstat /sc MINUTE /MO 1 /TR "c:\20165236netstatlog.bat",记录每隔两分钟计算机的联网情况:

8、运行此任务一段时间,在C盘打开创建的netstat5236.txt,查看本机在该时间段内的联网记录:


9、导入文本数据:新建excel文件,选择上方“数据”,选择“获取外部数据”,选择“自文本”

10、点击“导入” ,选中“分隔符号”

11、点击“下一步”,选全部分隔符号,点击“下一步” ,列数据格式选择常规,点击“完成”:


12、导入后数据如图:

13、生成柱形图即可分析各个联网的应用程序:

任务二 使用sysmon工具监控系统
1、sysmon是微软Sysinternals套件中的一个工具,使用sysmon工具前首先要配置相关文件,首先下载sysinternals,

再配置文件sysmon5236.xml,文件内容为:
<Sysmon schemaversion="4.20">
<!-- Capture all hashes -->
<HashAlgorithms>*</HashAlgorithms>
<EventFiltering>
<!-- Log all drivers except if the signature -->
<!-- contains Microsoft or Windows -->
<ProcessCreate onmatch="exclude">
<Image condition="end with">chrome.exe</Image>
<Image condition="end with">firefox.exe</Image>
</ProcessCreate>
<ProcessCreate onmatch="include">
<ParentImage condition="end with">cmd.exe</ParentImage>
</ProcessCreate>
<FileCreateTime onmatch="exclude" >
<Image condition="end with">chrome.exe</Image>
<Image condition="end with">firefox.exe</Image>
</FileCreateTime>
<NetworkConnect onmatch="exclude">
<Image condition="end with">chrome.exe</Image>
<Image condition="end with">firefox.exe</Image>
<SourcePort condition="is">137</SourcePort>
<SourceIp condition="is">172.30.0.142</SourceIp>
</NetworkConnect>
<NetworkConnect onmatch="include">
<DestinationPort condition="is">80</DestinationPort>
<DestinationPort condition="is">443</DestinationPort>
</NetworkConnect>
<CreateRemoteThread onmatch="include">
<TargetImage condition="end with">explorer.exe</TargetImage>
<TargetImage condition="end with">svchost.exe</TargetImage>
<TargetImage condition="end with">firefox.exe</TargetImage>
<TargetImage condition="end with">winlogon.exe</TargetImage>
<SourceImage condition="end with">powershell.exe</SourceImage>
</CreateRemoteThread>
</EventFiltering>
</Sysmon>

2、以管理员身份打开命令行,使用指令Sysmon.exe -i C:\sysmon5236.xml安装sysmon,

3、在事件查看器中的应用程序和服务日志,查看Microsoft->Windows->Sysmon->Operational,

4、打开之前实验3植入的20165236shellcode.upxed.exe后门,Kali用meterpreter回连,可以看到连接的信息,

5、在服务日志中发现有后门程序的痕迹,360安全的记录日志等等,在运行时后门程序会被拦截,如图:

2.2恶意软件分析
1、使用VirusTotal分析恶意软件
将实验3中生成的加壳后门在VirusTotal进行扫描,结果如图:

该恶意代码的基本属性如下,可以看出它的SHA-1、MD5摘要值、文件类型、文件大小 等等:

该恶意代码的算法库支持情况如图:

2、使用PEiD分析恶意软件
PEiD是一款著名的查壳工具,其功能强大,几乎可以侦测出所有的壳;
win7中下载并安装PEiD:

查看一下加过压缩壳的后门程序:

没有加壳的话则显示:什么也没发现,

3、动态分析——使用systracer分析恶意软件
在win7虚拟机下载安装SysTracer,

启动回连时,注册表发生了变化:

查看可得启用了很多dll文件:

查找到端口的连接:

三、实验过程中遇到的问题及解决方法
1、 使用sysmon工具监控系统时,安装sysmon过程中遇到如下问题:

原因及解决方法:版本不匹配,只需改成自己对应的版本号即可。
四、实验基础问题回答
1. 如果在工作中怀疑一台主机上有恶意代码,但只是猜想,所有想监控下系统一天天的到底在干些什么。
请设计下你想监控的操作有哪些,用什么方法来监控?
答:安装配置sysinternals里的sysmon工具,设置合理的配置文件,监控自己主机的重点事可疑行为,在事件查看器里找到相关日志文件查看;
2、如果已经确定是某个程序或进程有问题,你有什么工具可以进一步得到它的哪些信息?
答:(1)使用virscan分析可疑程序,分析文件行为;
(2)使用Wireshark进行抓包分析,查看该程序传输了哪些数据;
(3)使用TCPView查看可疑连接;
(4)使用systracer工具,比对前后区别,动态分析注册表修改情况和文件修改情况等,分析原因。
五、实验总结
本次实验涉及到了许多方面,比如说系统运行监控、分析恶意软件等等,我个人认为这些都是网络对抗课程中非常重要的技术。
其中涉及到的知识面也非常广泛。实验内容相对来说与较为复杂。为此我也参考了许多往届学长的博客,同时也查阅了一些资料,
并询问了老师同学,最终一步步完成了本次实验。
2018-2019-2 20165236 《网络对抗技术》Exp4 恶意代码分析的更多相关文章
- 2018-2019-2 20165325 网络对抗技术 Exp4 恶意代码分析
2018-2019-2 20165325 网络对抗技术 Exp4 恶意代码分析 实验内容(概要) 一.系统(联网)运行监控 1. 使用如计划任务,每隔一分钟记录自己的电脑有哪些程序在联网,逐步排查并且 ...
- 20145226夏艺华 网络对抗技术EXP4 恶意代码分析
20145226夏艺华 网络对抗技术EXP4 恶意代码分析(未完成版) 回答问题 (1)如果在工作中怀疑一台主机上有恶意代码,但只是猜想,所有想监控下系统一天天的到底在干些什么.请设计下你想监控的操作 ...
- 20155302《网络对抗》Exp4 恶意代码分析
20155302<网络对抗>Exp4 恶意代码分析 实验要求 •是监控你自己系统的运行状态,看有没有可疑的程序在运行. •是分析一个恶意软件,就分析Exp2或Exp3中生成后门软件:分析工 ...
- 20145208 蔡野 《网络对抗》Exp4 恶意代码分析
20145208 蔡野 <网络对抗>Exp4 恶意代码分析 问题回答 总结一下监控一个系统通常需要监控什么.用什么来监控. 监控一个系统通常需要监控这个系统的注册表,进程,端口,服务还有文 ...
- 20145215《网络对抗》Exp4 恶意代码分析
20145215<网络对抗>Exp4 恶意代码分析 基础问题回答 如果在工作中怀疑一台主机上有恶意代码,但只是猜想,所有想监控下系统一天天的到底在干些什么.请设计下你想监控的操作有哪些,用 ...
- 20155227《网络对抗》Exp4 恶意代码分析
20155227<网络对抗>Exp4 恶意代码分析 实践目标 1.是监控你自己系统的运行状态,看有没有可疑的程序在运行. 2.是分析一个恶意软件,就分析Exp2或Exp3中生成后门软件:分 ...
- 20155232《网络对抗》Exp4 恶意代码分析
20155232<网络对抗>Exp4 恶意代码分析 1.实践目标 1.1是监控你自己系统的运行状态,看有没有可疑的程序在运行. 1.2是分析一个恶意软件,就分析Exp2或Exp3中生成后门 ...
- 20155239 《网络对抗》Exp4 恶意代码分析
20155239 <网络对抗>Exp4 恶意代码分析 使用schtasks指令监控系统运行 先在C盘目录下建立一个netstatlog.bat文件,用来将记录的联网结果格式化输出到nets ...
- 20155304《网络对抗》Exp4 恶意代码分析
20155304<网络对抗>Exp4 恶意代码分析 实践内容 1.系统运行监控 1.1使用schtasks指令监控系统运行 我们在C盘根目录下建立一个netstatlog.bat的文本文件 ...
- 20155308《网络对抗》Exp4 恶意代码分析
20155308<网络对抗>Exp4 恶意代码分析 实践说明 实践目标 是监控你自己系统的运行状态,看有没有可疑的程序在运行. 是分析一个恶意软件,就分析Exp2或Exp3中生成后门软件: ...
随机推荐
- Zabbix导入数据库时报错
导入mysql数据库时报错: ERROR 1046 (3D000) at line 1: No database selected 解决办法:1.备份原来的sql文件2. yum -y install ...
- Cesium 动态更换模型贴图方法
参考资料 github 讨论地址 示例代码地址 示例代码 var viewer = new Cesium.Viewer('cesiumContainer'); var scene = viewer.s ...
- 使用Spring ThreadPoolTaskExecutor实现多线程任务
我们为何使用多线程,之前已经有讲过了,为了更快的处理多个任务,分割任务,或者调用多个毫无关联的第三方服务 其实spring就提供了ThreadPoolTaskExecutor这个类来实现线程池,线程池 ...
- call、apply、bind
***call,apply,bind 替换this 何时: 只要this不是想要的都可用call,apply,bind替换 选择: call/apply: *调用*函数,在调用时,*临时*替换函数中的 ...
- String hashcode的兴趣试玩
今天突然看到Hashcode和equals,==比较时,一时兴起,想了解一下hashcode生成规则,为什么hashcode相同,无法说明对象相等,但用equals说明相同,却可以推出对象的hashc ...
- FZU 2285 迷宫寻宝
思路: bfs求最短路径. #include<stdio.h> #include<iostream> #include<queue> #include<cst ...
- [PA2014]Budowa
[PA2014]Budowa 题目大意: 有A和B两名候选人.共有\(n(n\le1000)\)个人参加投票.他们之间形成了一个树结构,树上的结点有两种身份:专家(叶子结点)或领导(非叶子结点).每位 ...
- sql测验,like 和 = 的区别
.SQL 指的是? 您的回答:Structured Query Language .哪个 SQL 语句用于从数据库中提取数据? 您的回答:SELECT .哪条 SQL 语句用于更新数据库中的数据? 您 ...
- 一分钟掌握位运算符—与(&)、非(~)、或(|)、异或(^)
第一个版本: 位运算符的计算主要用在二进制中. 实际开发中也经常会遇到需要用到这些运算符的时候,同时这些运算符也被作为基础的面试笔试题. 所以了解这些运算符对程序员来说是十分必要的. 于此,记录下 ...
- numpy中的广播
目录 广播的引出 广播的原则 数组维度不同,后缘维度的轴长相符 数组维度相同,其中有个轴为1 参考: 广播的引出 numpy两个数组的相加.相减以及相乘都是对应元素之间的操作. import num ...