计算机虚拟机虚拟环境与代码动态变形技术ppt课件_第1页
计算机虚拟机虚拟环境与代码动态变形技术ppt课件_第2页
计算机虚拟机虚拟环境与代码动态变形技术ppt课件_第3页
计算机虚拟机虚拟环境与代码动态变形技术ppt课件_第4页
计算机虚拟机虚拟环境与代码动态变形技术ppt课件_第5页
已阅读5页,还剩28页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

虚拟机、虚拟环境与代码动态变形技术,1,目录,虚拟机保护的简介x86虚拟机保护的构建指令扩展式的构建第三方虚拟机的构建代码乱序代码替换花指令的构建问题,2,虚拟机保护的简介,起源保护的目的保护的对象保护的手段,3,x86虚拟机保护的构建,为什么要选取x86虚拟机开发周期短稳定性高避免重定位修复,4,x86虚拟机保护的构建,直接使用x86虚拟机做保护的不安全性编码的公开对x86虚拟机解释代码保护OPCODE表随机映射字节码的加解密变形后的指令处理句柄虚拟机上下文结构随机,5,x86虚拟机保护的构建,6,x86虚拟机保护的构建,字节码的加解密加密后指令1-decoder(随机的密钥)-指令1-HASH(指令1)=key1加密后指令2-decoder(key1)-指令2-HASH(指令2)=key2加密后指令3-decoder(key2)-指令3-HASH(指令3)=key3.,7,x86虚拟机保护的构建,变形后的指令处理句柄花指令插入指令扩展重定位,8,x86虚拟机保护的构建,虚拟机上下文结构随机结构字段的变换虚拟机上下文重定位结构用于与上下文结构一同传递,还原原始的上下文结构,9,x86虚拟机保护的构建,进入虚拟机之前要做的事情切换堆栈保存当前运行上下文,10,x86虚拟机保护的构建,异常的模拟内存访问权限不足未知指令,11,指令扩展保护,源于扭曲加密变换直接作用于PE文件指令模板化重定位的修复,12,指令扩展保护,指令模板化,指令扩展保护,例如一条指令addeax,1我们可以将它转化为callADD_EAX_1JmpADD_EAX_1_END;这里为垃圾代码ADD_EAX_1:pushebpmovebp,espsubesp,0 x08pushebxmovdwordptrebp-0 x04,5movebx,4subdwordptrebp-0 x04,ebxaddeax,dwordptrebp-0 x04movesp,ebppopebpRetADD_EAX_1_END:,14,指令扩展保护,重定位修复遍历代码,找出所有的跳转指令随机的插入代码重新遍历代码,找出所有的跳转指令通过第一次找出的偏移进行新偏移的修订,15,第三方虚拟机,最早可以在某些crackme中见到,用于保护算法指令编码的设计汇编器的设计调试器的设计,16,第三方虚拟机,壳的虚拟化壳的重要部分,IAT表修复,加解密运算,反调试模块使用新的汇编语言进行编写,17,第三方虚拟机,用户的自定义功能扩展编写反调试模块增加类似真实指令的伪指令区块,18,第三方虚拟机,19,第三方虚拟机,x86代码-虚拟机BYTECODE,20,虚拟机保护可能出现的BUG,外部函数动态跳转引发的状况从外部函数直接跳入到被保护的函数中,而不是头地址跳转是一个动态跳转,无法修复moveax,BaseAddressaddeax,Offsetjmpeax,21,代码乱序,增加逆向的难度让壳重新获得程序的控制权,22,代码乱序,23,代码替换,将要保护的代码替换为花指令,将被保护的代码放置到新的内存内。在执行被保护的代码时跳转到新的内存。,24,代码替换,找到两个JMP/CALL/JCC之间的代码段并记录到结构遍历这个结构,把要替换的代码段搬运到新的空间,在新的空间末尾添加一个跳入原先代码段结束的地址将原先的代码块的首5个字节添加一个JMP跳入到搬运后的地址。并填充同样长度的花指令将这个代码块除了首5个字节其余字节以花指令填充,25,偏移的修复,设:目标地址为y,从JMP或者CALL后取出的偏移为x,JMP或者CALL的指令长度为I,当前地址为C。第一个公式y=C+x+I第二个公式y=C-(x)+1)-I),26,花指令的产生器的构建,根据随机率产生随机的花指令根据要产生的长度随机产生花指令,27,花指令的产生器的构建,28,花指

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论