首页
社区
课程
招聘
[旧帖] [求助]关于BeaEngine的崩溃求助 0.00雪花
发表于: 2014-8-3 17:41 1692

[旧帖] [求助]关于BeaEngine的崩溃求助 0.00雪花

2014-8-3 17:41
1692
本人菜鸟一只,最近在学习PE结构和调试相关的,找了天道酬勤的调试器开发视频,但是第一课就遇到了问题。

BeaEngine崩溃了。。。

系统是win8.1 64位 +  vs2008sp1 + VA

但是放在虚拟机里的xp sp3中就没有问题

以下是代码


// 01Dasm.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

LONGLONG GetEip() ;

int _tmain(int argc, _TCHAR* argv[])
{
	DISASM stDasm = {} ;
	LONGLONG lEip = GetEip() ;
	if (-1 == lEip)
	{
		return -1;
	}
	stDasm.EIP = lEip ;

	UINT nCount = 0 ;
	int nLen = -1 ;

	while(nCount ++ < 100)
	{
		[COLOR="Red"]nLen = Disasm(&stDasm) ;[/COLOR]
		if (nLen != UNKNOWN_OPCODE)
		{
			_tprintf(_T("Line:%d\t"),nCount) ;
			puts(stDasm.CompleteInstr) ;
			stDasm.EIP += nLen ;
		}
		else
		{
			break;
		}
	}
	_tsystem(_T("pause")) ;
	return 0;
}

LONGLONG GetEip()
{
	HANDLE hFile = INVALID_HANDLE_VALUE ;
	TCHAR tszFileName[MAX_PATH] = {0} ;
	IMAGE_DOS_HEADER iDosHeader = {0} ;
	IMAGE_NT_HEADERS iNTHeader = {0} ;
	DWORD dwBytesRead = 0 ;
	do 
	{
		GetModuleFileName(NULL, tszFileName, MAX_PATH) ;
		//lstrcpy(tszFileName, _T("dasm.exe")) ;
		hFile = CreateFile(tszFileName,GENERIC_READ, FILE_SHARE_READ, 
			NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL) ;
		if (INVALID_HANDLE_VALUE == hFile)
		{
			break;
		}

		if(!ReadFile(hFile, &iDosHeader, sizeof(IMAGE_DOS_HEADER), &dwBytesRead, NULL))
		{
			break;
		}
		if (IMAGE_DOS_SIGNATURE != iDosHeader.e_magic)
		{
			break ;
		}

		SetFilePointer(hFile, iDosHeader.e_lfanew, NULL, FILE_BEGIN) ;

		if(!ReadFile(hFile, &iNTHeader, sizeof(IMAGE_NT_HEADERS), &dwBytesRead, NULL))
		{
			break;
		}
		if (IMAGE_NT_SIGNATURE != iNTHeader.Signature)
		{
			break;
		}
	} while (FALSE);

	if (hFile)
	{
		CloseHandle(hFile) ;
		return (LONGLONG)(iNTHeader.OptionalHeader.AddressOfEntryPoint+ iNTHeader.OptionalHeader.ImageBase) ;
	}
	return -1 ;
}







这是崩溃的具体报告
就是在调用BeaEngine那一行崩溃的  错误代码5


这是反汇编中显示的信息,ebp的值是正确的,但是在自动窗口中居然是0

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

上传的附件:
收藏
免费 0
支持
分享
最新回复 (2)
雪    币: 1443
活跃值: (101)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
你没处理重定位,从0x00401000开始反汇编的,但是在win7上这个地址可能根本不可读。
2014-8-4 06:44
0
雪    币: 209
活跃值: (14)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
3
果不其然是这样 。。。。。。。。

我对于重定位不是很了解

我就是知道PE文件里的重定位表中的重定位代码是要根据加载是的基址变化的,那么没有在里面的为什么也需要修正才行呢。

我试了只是修正重定位表中的数据还是会读权限错误。全部修正就没事了。。

这很困惑诶!

以下是修正后的代码
// 01Dasm.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

using std::set ;
using std::vector ;

set<DWORD> setRelBaseAddr ; //放置重定位地址
vector<IMAGE_SECTION_HEADER> vetSetions ;//放置区段头信息,用于将RVA转换成RAWoffset
LPSTR lpMapFileBase = NULL ;//文件映射的基址

LONGLONG GetEip(DWORD& dwBase) ;//取得PE入口,参数用于保存PE中的imagebase。
DWORD GetBaseAddrAfterLoad(LPWSTR lpwszModuleName) ;//取得实际载入内存的基址
void AddRelBaseAddrToSet() ;//把需要重定位的地址放入集合中
INT AccessDeniedFilter(DWORD dwExceptionCode, DWORD dwBase, DWORD dwNew, LPDISASM lpDisasm) ;//SEH的过滤函数
int RAVToRawOffset(DWORD ImageBase, DWORD dwBase) ;

int _tmain(int argc, _TCHAR* argv[])
{
	DWORD dwNewBaseAddr = 0 ;
	DWORD dwDefaultBaseAddr = 0 ;
	AddRelBaseAddrToSet() ;//最初就遍历重定位表  放入集合
	DISASM stDasm = {} ;
	LONGLONG lEip = GetEip(dwDefaultBaseAddr) ;//得到eip的 rva
	_tprintf(_T("base addr: 0x%08x , new base addr: 0x%08x\n"),dwDefaultBaseAddr, dwNewBaseAddr = GetBaseAddrAfterLoad(L"01dasm.exe")) ;
	if (-1 == lEip)
	{
		return -1 ;
	}

	stDasm.EIP = lEip + dwNewBaseAddr;//加上新的基址就是内存偏移,不管是否与建议装载地址相同
	

	UINT nCount = 0 ;
	int nLen = -1 ;


	//_tsystem(_T("pause")) ;
	while(nCount ++ < 1500)
	{
		__try//进行SEH处理
		{
			nLen = Disasm(&stDasm) ;
			if (nLen != UNKNOWN_OPCODE)
			{
				_tprintf(_T("0x%08x:"),stDasm.EIP) ;
				puts(stDasm.CompleteInstr) ;
				stDasm.EIP += nLen ;
			}
			else
			{
				_tprintf(_T("DASM ERROR\n")) ;
				break;
			}
		}
		__except(AccessDeniedFilter(GetExceptionCode(), dwDefaultBaseAddr, dwNewBaseAddr, &stDasm))
		{
			_tprintf(_T("Unkown Error! \n")) ;
			break;
		}
	}
	_tsystem(_T("pause")) ;
	return 0;
}

LONGLONG GetEip(DWORD& dwBase)
{
	HANDLE hFile = INVALID_HANDLE_VALUE ;
	TCHAR tszFileName[MAX_PATH] = {0} ;
	IMAGE_DOS_HEADER iDosHeader = {0} ;
	IMAGE_NT_HEADERS iNTHeader = {0} ;
	DWORD dwBytesRead = 0 ;
	do 
	{
		GetModuleFileName(NULL, tszFileName, MAX_PATH) ;

		hFile = CreateFile(tszFileName,GENERIC_READ, FILE_SHARE_READ, 
			NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL) ;
		if (INVALID_HANDLE_VALUE == hFile)
		{
			break;
		}

		if(!ReadFile(hFile, &iDosHeader, sizeof(IMAGE_DOS_HEADER), &dwBytesRead, NULL))
		{
			break;
		}
		if (IMAGE_DOS_SIGNATURE != iDosHeader.e_magic)
		{
			break ;
		}

		SetFilePointer(hFile, iDosHeader.e_lfanew, NULL, FILE_BEGIN) ;

		if(!ReadFile(hFile, &iNTHeader, sizeof(IMAGE_NT_HEADERS), &dwBytesRead, NULL))
		{
			break;
		}
		if (IMAGE_NT_SIGNATURE != iNTHeader.Signature)
		{
			break;
		}
	} while (FALSE);

	if (hFile)
	{
		CloseHandle(hFile) ;
		dwBase = iNTHeader.OptionalHeader.ImageBase ;
		return (LONGLONG)(iNTHeader.OptionalHeader.AddressOfEntryPoint) ;
	}
	return -1 ;
}

DWORD GetBaseAddrAfterLoad(LPWSTR lpwszModuleName)
{
	DWORD dwPID = GetCurrentProcessId() ;

	HANDLE hTlHelp = INVALID_HANDLE_VALUE ;

	hTlHelp = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE, dwPID) ;

	if (INVALID_HANDLE_VALUE == hTlHelp)
	{
		return 0 ;
	}

	MODULEENTRY32 me32 = {sizeof(MODULEENTRY32)} ;
	if (Module32First(hTlHelp, &me32))
	{
		do 
		{
			if (0 == lstrcmpiW(me32.szModule, lpwszModuleName))
			{
				CloseHandle(hTlHelp) ;
				return (DWORD)me32.modBaseAddr ;
			}
		} while (Module32Next(hTlHelp, &me32));
	}

	CloseHandle(hTlHelp) ;
	return 0 ;

}



void AddRelBaseAddrToSet()
{
	IMAGE_DOS_HEADER iDosHeader = {0} ;
	IMAGE_NT_HEADERS iNTHeader = {0} ;
	//
	TCHAR tszFileName[MAX_PATH + 1] = {0} ;
	if (!setRelBaseAddr.empty())
	{
		setRelBaseAddr.clear() ;
	}
	GetModuleFileName(NULL, tszFileName , MAX_PATH) ;
	HANDLE hFile ;
	HANDLE hFileMap ;

	do 
	{
		hFile = CreateFile(tszFileName,GENERIC_READ, FILE_SHARE_READ, 
			NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL) ;
		if (INVALID_HANDLE_VALUE == hFile)
		{
			break ;
		}

		hFileMap = CreateFileMapping(hFile,NULL,PAGE_READONLY,0,0,NULL) ;
		if (NULL == hFileMap)
		{
			break  ;
		}

		lpMapFileBase = (LPSTR)MapViewOfFile(hFileMap, FILE_MAP_READ, 0 , 0 , 0) ;

		if (NULL == lpMapFileBase)
		{
			break;
		}

		LPSTR lpTmpAddr = lpMapFileBase ;

		memcpy_s(&iDosHeader, sizeof(IMAGE_DOS_HEADER), lpTmpAddr, sizeof(IMAGE_DOS_HEADER)) ;
		lpTmpAddr += iDosHeader.e_lfanew ;
		memcpy_s(&iNTHeader, sizeof(IMAGE_NT_HEADERS), lpTmpAddr, sizeof(IMAGE_NT_HEADERS)) ;
		lpTmpAddr += sizeof(IMAGE_NT_HEADERS) ;

		vetSetions.clear() ;
		IMAGE_SECTION_HEADER iSectionHeader = {0} ;
		for(int i = 0 ; i < iNTHeader.FileHeader.NumberOfSections ; i ++)
		{
			ZeroMemory(&iSectionHeader, sizeof(IMAGE_SECTION_HEADER)) ;
			memcpy_s(&iSectionHeader,sizeof(IMAGE_SECTION_HEADER),lpTmpAddr,sizeof(IMAGE_SECTION_HEADER)) ;
			lpTmpAddr += sizeof(IMAGE_SECTION_HEADER) ;
			vetSetions.push_back(iSectionHeader) ;
		}

		DWORD dwSizeofBlock = 0 ;
		DWORD dwRelVirtrualAddr =  0; 

		dwRelVirtrualAddr = iNTHeader.OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_BASERELOC].VirtualAddress ;
		lpTmpAddr = lpMapFileBase + RAVToRawOffset(dwRelVirtrualAddr + iNTHeader.OptionalHeader.ImageBase, iNTHeader.OptionalHeader.ImageBase) ;

		WORD wRelBlock = 0 ;
		DWORD dwAddrNeedRel = 0 ;
		while(dwRelVirtrualAddr = *((DWORD*)lpTmpAddr))
		{
			dwSizeofBlock = ( *((DWORD*)lpTmpAddr + 1)  - sizeof(IMAGE_BASE_RELOCATION)) / 2 ;
			lpTmpAddr += 8 ;
			for (DWORD i = 0 ; i < dwSizeofBlock ; i ++)
			{
				wRelBlock = *((WORD*)lpTmpAddr) ;
				lpTmpAddr += 2 ;
				if (0x03000 == (wRelBlock & 0x0f000))
				{
					dwAddrNeedRel = iNTHeader.OptionalHeader.ImageBase + dwRelVirtrualAddr + (DWORD)(wRelBlock & 0x0fff) ;
					setRelBaseAddr.insert(dwAddrNeedRel) ;
				}
			}
		}

	} while (FALSE);

	if (lpMapFileBase)
	{
		UnmapViewOfFile(lpMapFileBase) ;
	}

	if (hFileMap)
	{
		CloseHandle(hFileMap) ;
	}
	if (INVALID_HANDLE_VALUE != hFile)
	{
		CloseHandle(hFile) ;
	}

}

INT AccessDeniedFilter(DWORD dwExceptionCode, DWORD dwBase, DWORD dwNew, LPDISASM lpDisasm)
{
	if (EXCEPTION_ACCESS_VIOLATION != dwExceptionCode)
	{
		return EXCEPTION_EXECUTE_HANDLER ;
	}


	if (setRelBaseAddr.end() != setRelBaseAddr.find(lpDisasm->EIP) && (dwBase != dwNew))
	{
		lpDisasm->EIP = lpDisasm->EIP - dwBase + dwNew ;
		return EXCEPTION_CONTINUE_EXECUTION ;
	}

	return EXCEPTION_EXECUTE_HANDLER ;

}

int RAVToRawOffset(DWORD RVA, DWORD dwBaseAddr)
{
	for(vector<IMAGE_SECTION_HEADER>::iterator it = vetSetions.begin();
		it != vetSetions.end();it++)
	{
		if (RVA >= dwBaseAddr + it->VirtualAddress  && RVA <= dwBaseAddr + it->VirtualAddress + it->SizeOfRawData)
		{
			return it->PointerToRawData + RVA - it->VirtualAddress - dwBaseAddr ;
		}
	}
	return -1 ;
}


2014-8-6 21:33
0
游客
登录 | 注册 方可回帖
返回
//