1 查看信息

  • 使用ExeInfoPe查看此壳程序

  • 可以看出是很老的FSG壳。

分析:

Entry Point : 000000154,熟悉PE结构的知道,入口点(代码)揉进PE头去了。

在WIN10 以来在(被限制了)PE 头中不能有执行代码,只有在WIN7 及其以前的机器上,此程序才能执行。所以用虚拟机来脱这个很老的壳,在目前(本人)win10的机器上无法运行。

2 使用LordPE 观察以下PE结构

  • 点击查看区段 信息:

  • 分析:

发现区段有两个,都把区段名抹去了;且第一个区段的虚拟大小虽然0x17000 但是实际大小(文件中的大小)是0

3 使用OD调试此程序尝试找OEP

3.1 打开OD定位壳

  • 用Nop 破坏花指令使得反汇编正确解析后,添加注释、标签 - "FSG壳"

分析: 我们发现一进来,壳早就准备好了全部寄存器数据在地址0x4219D8的位置,把当前位置保存环境的地址放到当前的ESP寄存器,那就能POP栈操作,操作壳保存好的数据了。为啥我们看不到它之前的操作? 之后写壳的时候再分析

3.2 尝试找 OEP

  • 单步运行
  • 遇到第一个call (字符操作核心部分)

0x000400160:

CALL DWORD PTR DS:[EBX]
;此时EBX是 0x4219dc --- [EBX]:是0x4001e8

进入 0x4001e8:

结合 call 的下一句 大致理解这个算法

分析:

这个字符串拷贝的算法,(浅淡的观测下)不可逆的拷贝,而且信息不全,所以可能不重要。

我们可以先忽略这个拷贝循环 -----》 跳过这个拷贝算法: 我们在后面的每个 jmp/call 鼠标点过去一下看会不会跳回去之类的,直到找到了。

或者你安装了高亮插件(asmHighLight.dll):由于我们分析出这个拷贝的核心调用函数是 地址为 0x400160 这句opcode,那鼠标点在上面查看后面在哪里没有该高亮色,就大致找一下就能跳过这个算法部分了。

然后我们在壳代码后面部分找到了最后一个高亮。其实这个无条件跳转流这就是我们这个算法部分的最后一句了。

  • 跳出字符串拷贝算法之后,我们发现代码只有10来行了。直接断点关键的跳转行,我们直接找OEP。

  • 然后我们发现跳转到 OEP的是这一句:

4 Dump

  • 进入入口函数后,我们点几个跳转点数据等 并没有发现有异常数据(异常数据)等。直接使用OD提供的插件ollyDump ,dump到本地。

分析:

观察其实地址 、入口点这些 头没有错。如果没有就点击脱壳

5 修复IAT

  • 这里使用impREC 来修复IAT

我们发现这里查找出来的IAT信息不完全,那就需要观察IAT表是否有异常了。

分析:

通过这里找到的函数偏移,可以迅速定位到IAT表。

比如这里的rva为B000。那么再虚拟空间中的地址就是40B000,在OD中观察如下:

  • 我们向下滑动,发现:

这两个异常值阻止了impREC的解析:我们该为正常的0000000间隔:

我们修改后再次用impREC解析 得到的IAT表目前来看貌似完成了

  • 最后点击修复转储到我们刚才用OD,dump出来的的程序

6 检测我们的脱壳之后的程序

yes!!!

---恢复内容结束---

最新文章

  1. workman源代码阅读 - 使用信号处理器实现定时器
  2. 《java数据结构和算法》读书笔记
  3. node命令
  4. HDOJ 4751 Divide Groups
  5. 使用C# WinForm窗体制作经理评分项目 ——S2 2.2
  6. Bootstrap Alert Auto Close
  7. Select标签 依据value值默认选中 Jquery
  8. QCA4002/QCA4004 为主流家电和消费电子产品推出低功耗Wi-Fi平台
  9. 炫酷的CSS3发光搜索表单,附演示和源码
  10. 天体程序猿叹息——变化hosts对
  11. 0-ajax操作json(番外篇)
  12. 第20章 数据库操作----JDBC概述
  13. 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
  14. 计科1702冯亚杰C语言程序设计预备作业
  15. promise知识点小结
  16. 深度学习原理与框架- tf.nn.atrous_conv2d(空洞卷积) 问题:空洞卷积增加了卷积核的维度,为什么不直接使用7*7呢
  17. 【原创】Python第二章——字符串
  18. Hiberbate注解
  19. cf777c 模拟
  20. 201621123001《Java程序设计》第4周学习总结

热门文章

  1. 编写loadrunner的ftp脚本(详细步骤)
  2. 使用Python爬取微信公众号文章并保存为PDF文件(解决图片不显示的问题)
  3. php实现redis锁机制
  4. SSM(五)Mybatis配置缓存
  5. Java web环境的搭建
  6. vue回顶部 组件 可以直接使用
  7. CSS3 入门级
  8. Spring Boot2(六):使用Spring Boot整合AOP面向切面编程
  9. bugku welcome to bugkuctf
  10. css 全局样式表