能力值:
(RANK:260 )
|
-
-
2 楼
VA,虚拟地址,也就是程序被加载到内存中的地址
RVA,以虚拟地址前边加上个“相对的”,也就是说它还是按虚拟地址来换算,只不过不是从0开始,而是把一个模块的基址作为参考点。
RAW ADRRESS,或者FILE OSSFET,一般称文件偏移,你把一个文件看成一个连续的字节流,OFFSET就是这个字节流中的位置。
换算关系为:
将VA减去MODULE的BASE就是RVA的值。
RVA与OFFSET的关系,是通过每个SECTION内领衔量相等为换算的。举例来说,假设一个EXE文件,BASE为0x00400000,第一个SECTION的名字叫.text,它的RVA是0x2000,那么它的VA就是0x00402000,也就是它个SECTION在内存中的起始地址是0x00402000;若假设这个SECTION的OFFSET是0x1000,那么最终的结果是,文件中从0x1000开始的一个SECTION,被映射到了内存地址0x00402000开始的内存区间。假设有一段代码位于这个SECTION中,它的地址(VA)是0x00402345,相当于它的RVA是0x2345,而它在SECTION内部的偏移量是0x0345,所以它的文件中的偏移量就是0x1000(SECTION的起始偏移量) + 0x0345,即0x1345。
总结:VA与RVA只相差一个BASE值,而VA与OFFSET的换算,关键是要确定这个地址属于哪一个SECTION。
|
能力值:
( LV2,RANK:10 )
|
-
-
3 楼
ImportREC_fix这个软件 的OEP地直是怎么算出来的呢 不太会~~~
|
能力值:
(RANK:260 )
|
-
-
4 楼
这个不是ImportRec给你“算”出来的,是要人输入的。
脱壳时,通常是在调试器里走到程序的OEP,然后DUMP内存映像,再把OEP的地址换算成RVA,用来修复DUMP出的文件头(以及用来帮助ImportRec那年IAT,但IAT也可以手动寻找)。
|
能力值:
( LV2,RANK:10 )
|
-
-
5 楼
恩我的意思是说 假设 我在OD中看到的 OEP是 BB86BB86 为什么到 到ImportREC_fix 就是 6BB86了
|
能力值:
(RANK:260 )
|
-
-
6 楼
OEP不可能是 BB86BB86,这是内核空间了。
你现在明白VA和RVA的关系了吗?
我告诉你在调试器里的OEP是它的VA,你难道不会算它的RVA?
|
能力值:
( LV2,RANK:10 )
|
-
-
7 楼
好的谢谢啦 我在研究研究~
|
能力值:
( LV2,RANK:10 )
|
-
-
8 楼
为什么RVA是0x2000而文件的OFFSET却是0x1000?
|
能力值:
( LV9,RANK:180 )
|
-
-
9 楼
楼上没看到二楼的用心
|
能力值:
( LV2,RANK:10 )
|
-
-
10 楼
应该和PE这种老外结构有关.
导致RVA和OFFSET不相等的原因可能是...
如果相等的话.那就是...
|
能力值:
( LV2,RANK:10 )
|
-
-
11 楼
http://bbs.pediy.com/showthread.php?t=61737 发现这里介绍的比较祥细!!!!
还有谢谢大家的帮助 又学到一点
|
|
|