当然啦,这里放一个我在2020年天府杯国际网络安全大赛上完成的QEMU逃逸视频,影响Qemu5.2以前的版本号。通俗一点讲就是我在客户机内运行了一小段恶意驱动程序,发送恶意数据给Hypervisor(也就是我们熟知的虚拟机,例如Vmware、Virtualbox、QEMU)触发其本身的安全漏洞。通过一些内存布局的手段我们就可以完成漏洞利用,实现RCE(远程代码执行)啦。最终效果就是在主机上弹出一个计算器,当然你想干其他任何事情也都可以,因为此时你已经在客户机端拿到主机的完全控制权限了。
这个漏洞已经公开,传送门:【Black Hat Asia 2021分享】清道夫:误用“错误处理代码”导致的QEMU/KVM逃逸 https://zhuanlan.zhihu.com/p/373084566
当然可以逃得出去,别小瞧了现代黑客的技术。
其实虚拟机的本质也是运行在操作系统上的一个应用软件而已,和你打开的chrome、QQ、网易云音乐、LOL等没有什么大的区别,只不过这个应用软件会独立的运行另外一个操作系统而已。
因此,虚拟机实际上也不是能够和真实主机完全隔离,来保证绝对安全的,在一部分情况下还是会影响到主机的安全性,例如软件漏洞逃逸和硬件逃逸等等。
在虚拟机安全中,有个专业的名词就叫做虚拟机逃逸,指的是进程越过虚拟机范围,进入到宿主机的操作系统中,也就是题目中提到的病毒逃离虚拟机,对真实主机造成危害。
这种情况常有发生,例如:
17年在温哥华举行的Pwn2Own黑客大赛,360安全团队便通过利用Edge中的堆溢出漏洞,Windows内核中的类型混淆漏洞以及VMware中的未初始化的缓冲区漏洞进行了黑客攻击,以逃避运行Microsoft VMware Workstation虚拟机的方式破坏了微软的Edge浏览器,拿走了105,000刀的奖金。
一般试图进行虚拟机逃逸的恶意软件都必须先瞄准特定虚拟机配置中的已知缺陷,并依赖于预先了解主机环境中的一部分信息。大多数现实世界的虚拟机逃脱的目标是VirtualBox,比如:
回答问题的时候,我还在YouTube上找到了几个虚拟机逃逸的演示视频,比如这个:
另外,一些恶意代码会检测它是否在虚拟机环境中运行,目前已经公布了许多技术可以用来检测虚拟机。VMware并不认为这是一个安全漏洞,所以也没有采取明确的技术措施,来避免检测。 但一些恶意代码会在虚拟机环境中有着不同的执行过程, 这也会加重一部分恶意代码分析师的工作负担。
与其他所有的应用软件一样, VMware本身偶尔也会被曝出安全漏洞。而这些安全漏洞被利用,会导致宿主机操作系统崩溃,甚至在上面运行恶意的代码。尽管只有少数公共工具或论文显示了攻击VMware的技术,但是目前在共享目录特性中已经被发现了安全漏洞,而且也公开发布了利用拖放功能的攻击工具。
目前已经在共享文件夹功能或者共享工具中发现了很多公开的漏洞,它们都利用了VMware Tools的拖放功能。一个使用了文件夹共享功能的公开漏洞,可以使Guest系统在宿主系统上写任何文件,从而修改或者破坏宿主操作系统。
虽然这种特别的技术对当前版本的VMware无效,但在文件夹共享功能上已经发现了几个不同的安全漏洞,因此最好确保自己的VM软件有完整的补丁修复,或者通过在虚拟机中禁用文件夹共享功能,也可以阻止这种类型的攻击。
在以前的时候,恶意代码编写者也经常使用反虚拟机技术来逃避恶意代码分析,恶意代码可以使用这种技术探测自己是否运行在虚拟机中。如果恶意代码探测到自己在虚拟机中运行,它会执行与其本身行为不同的行为, 其中最简单的行为就是是停止运行。
这种反虚拟机技术给恶意代码分析者带来不少的难题。
不过随着虚拟化技术的使用不断增加,这种采用反虚拟机技术的恶意代码数量也在逐渐下降,因为无论是计算机管理员还是普通计算机用户都在使用虚拟机,所以即使目标主机是虚拟机,其也有攻击价值,黑客也不能够对其像之前一样视而不见了。
关于虚拟机安全方面,我了解的内容大致如上
可以。
按最狭义的定义,“病毒逃出虚拟机”指恶意程序透过hypervisor对母机系统进行任意代码执行攻击,这种攻击被称为hyperjacking。根据维基百科的说法,VENOM漏洞在2015年被登记为CVE(可以翻译成公共漏洞披露),是已知最早的可能实际导致hyperjacking攻击的漏洞。
如果把“病毒”和“虚拟机”的定义放宽,那例子就多了。
比如有一种经典的攻击方式叫做缓存计时攻击,因为母机和所有虚拟机共用一套CPU缓存,所以恶意程序可以通过这种方法窃取母机或其他虚拟机的数据。前几年闹得沸沸扬扬的英特尔meltdown漏洞就是一种缓存计时攻击,当时各大浏览器同时降低JS的计时器精度就是为了防止网页利用缓存计时窃取数据。
还有一些虚拟机本身不提供安全保证,比如带JNI功能的Java虚拟机,native code通过stack overflow可以轻易地破坏虚拟机调用栈。Android的ART和Dalvik就是这一类虚拟机,所以它在虚拟机外面又包了一层Linux用户隔离来保证安全性。
病毒会不会感染另一台电脑?!当然可以
病毒会不会逃出虚拟机?!当然可以
两者理论上是一样的。
本站所有内容均为互联网搜索引擎提供的公开搜索信息,本站不存储任何数据与内容,任何内容与数据均与本站无关,如有需要请联系相关搜索引擎包括但不限于百度,google,bing,sogou 等
© 2025 tinynews.org All Rights Reserved. 百科问答小站 版权所有