首页 > 其他 > 详细

简单调试器的实现(三)完善调试器

时间:2015-03-28 20:06:58      阅读:244      评论:0      收藏:0      [点我收藏+]

Dll加载:

case LOAD_DLL_DEBUG_EVENT:
// Read the debugging information included in the newly
// loaded DLL. Be sure to close the handle to the loaded DLL
// with CloseHandle.

//Dll加载时会进行这个事件

dwContinueStatus = OnLoadDllDebugEvent(DebugEvent);
break;

 

DWORD OnLoadDllDebugEvent(const LPDEBUG_EVENT DebugEvent)
{
//我们可以通过DebugEvent->u.LoadDll.hFile获得Dll的句柄

//但是,没有直接从HANDLE->Path的API,需要代码进行转化

//具体方法很容易查找到,这里就不介绍了。

  GetFileNameFromHandle(DebugEvent->u.LoadDll.hFile);

  return DBG_CONTINUE;
}

 

读取内存:

 

读取内存的API我们已经介绍过了ReadProcessMemory。

部分代码:

//Addr  读取的地址

//Size = sizeof(BYTE)

void *lpBuff;

lpBuff = malloc(Size);

SIZE_T bytesRead;

 

for (i = 0; i < 32; i++)
{
  if ((i % 8) == 0)      //输出4行 8列
    printf("\n%x ", Addr);
  if (FALSE == ReadProcessMemory(G_Process, Addr, lpBuff, Size, &bytesRead))
  {
    printf("?? ");      //读取失败就输出" ??"
  }
  else
  {
    printf("%.2x ", *(BYTE*)lpBuff);
  }
  Addr = Addr + Size;
}

free(lpBuff);

 效果:

技术分享

 

这章就讲这么多了。。。下一章节将详细的讲解软断点。

简单调试器的实现(三)完善调试器

原文:http://www.cnblogs.com/Windogs/p/4373541.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!