Loader简介----1

来源:岁月联盟 编辑:猪蛋儿 时间:2012-05-16

做完文件校验后将映像映射到内存当中。


[cpp]
/*
* 将文件内容按虚拟地址信息映射到地址空间,返回模块的基地址
*/ 
char* LdrLayoutPe(char*pImage, DWORD FileSize) 

    PIMAGE_FILE_HEADER pFileHeader; 
    PIMAGE_SECTION_HEADER pSectionHeader; 
    char* pOptionalHeader; 
    char* pImageBase; 
    char* pRealImageBase; 
    DWORD SizeOfImage; 
    WORD Magic; 
    DWORD i; 
 
    if(!LdrValidateImage(pImage, FileSize)) 
        return NULL; 
    pFileHeader = _GetFileHeaderFromPe(pImage); 
    pSectionHeader = _GetSectionHeaderFromPe(pFileHeader); 
    pOptionalHeader = (char*)pFileHeader + sizeof(IMAGE_FILE_HEADER); 
    Magic = *(WORD*)pOptionalHeader; 
    pImageBase = _GetImageBaseFromPe(pFileHeader); 
    SizeOfImage = *(DWORD*)(pOptionalHeader + 0x38); 
    pRealImageBase = (char*)VirtualAlloc(pImageBase, SizeOfImage, MEM_RESERVE|MEM_COMMIT, PAGE_READWRITE); 
    if(!pRealImageBase){ 
        pRealImageBase = (char*)VirtualAlloc(NULL, SizeOfImage, MEM_RESERVE|MEM_COMMIT, PAGE_READWRITE); 
        if(!pRealImageBase) 
            return FALSE; 
    } 
    //拷贝文件头信息 
    RtlCopyMemory(pRealImageBase, pImage, (char*)pSectionHeader - pImage + pFileHeader->NumberOfSections*sizeof(PIMAGE_SECTION_HEADER)); 
    //拷贝节信息到内存 
    for(i = 0; i < pFileHeader->NumberOfSections; i++){ 
        if(!pSectionHeader[i].PointerToRawData) 
            continue; 
        RtlCopyMemory(pRealImageBase + pSectionHeader[i].VirtualAddress, 
            pImage + pSectionHeader[i].PointerToRawData, pSectionHeader[i].SizeOfRawData); 
    } 
    return pRealImageBase; 

 


摘自 云淡风轻

图片内容