180319 逆向-代码的二次开发(1)区块间隙的利用

1625-5 王子昂 总结《2018年3月19日》 【连续第534天总结】
A. 代码的二次开发(1)
B.

前言

这里的二次开发主要指的是在没有源码和接口的情况下扩充可执行文件的功能,目标是二进制的EXE或DLL文件,需要用汇编实现相关功能,或构造一个接口,调用其他语言实现功能。该技术主要是修改扩充PE结构,对PE文件进行DIY,因此又叫PEDIY技术

增加空间

最首要解决的就是新增加的代码放在哪里的问题
有两种方法

  • 在区块间隙中添加
  • 新增区块

区块间隙

由于PE文件每个区块的大小必定等于磁盘对齐值(FileAlignment)的整数倍,因此造成实际代码空间与对齐空间的间隙
每个区块末尾都有一段空白的、以00填充的内存可用

利用区块间隙时,必须注意区块的属性(Characteristics),它决定了该区块是否可读写。
默认情况下一般只有.data数据段是可写的,而.text代码段则是只读。
在具备可写属性的区段中添加代码,可能会被程序误当作未初始化空间而征用,导致代码被改动进而出错。因此最好在只读属性的区段中改动。

C. 明日计划
手工构造区块

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值