日期:2014-05-16  浏览次数:20811 次

pe中的基址重定位问题
pe中的基址重定位

typedef struct {
    DWORD   virtualAddress;
    DWORD   sizeOfBlock;
    WORD   typeOffset;
}IMAGE_BASE_RELOCATION;
为什么要用virtualAddress和typeOffset相加的方式来确定要改变的地址在exe文件中的file offset,而不直接指向file offset 或者只用一个RVA不就可以了么?





demo:

.......
call dword ptr [40200E]
......

如果dll默认被转载在0x400000地址,想在windows决定将它加载到0x870000,windows将如何转换这条指令到指定的内存,在内存中的dump中这条指令会发生变化么,如果变了是如何变的,讲解下原理。
PE 内存 exe windows

------解决方案--------------------
这样做通常情况下比较节省重定位数据的空间吧,尤其是导入函数,将它们集中在一起时,基本上一个项就一个 word 表示了,否则一个项要有一个 dword 即两个 word 了
------解决方案--------------------
未重定位前是call dword ptr [200E]