Advanced Debugging
About AdvDbg Consult Train Services Products Tools Community Contact  
欢迎光临 高端调试 登录 | 注册 | FAQ
 
  ACPI调试
Linux内核调试
Windows内核调试
 
  调试战役
调试原理
新工具观察
 
  Linux
Windows Vista
Windows
 
  Linux驱动
WDF
WDM
 
  PCI Express
PCI/PCI-X
USB
无线通信协议
 
  64位CPU
ARM
IA-32
  CPU Info Center
 
  ACPI标准
系统认证
Desktop
服务器
 
  Embedded Linux
嵌入式开发工具
VxWorks
WinCE
嵌入式Windows
 
  格蠹调试套件(GDK)
  格蠹学院
  小朱书店
  老雷的微博
  《软件调试》
  《格蠹汇编》
  《软件调试(第二版)》
沪ICP备11027180号-1

WinDbg

帖子发起人: Thomson   发起时间: 2009-07-21 20:54 下午   回复: 4

Print Search
帖子排序:    
   2009-07-21, 20:54 下午
Thomson 离线,最后访问时间: 2013/3/31 11:42:42 Thomson

发帖数前10位
注册: 2008-07-03
发 贴: 211
如何在程序里面定位到其他进程的peb地址?
Reply Quote
如果不通过symbols(ntdll!_PEB)来找的话?
用dbgeng里面的GetExpression("@$PEB"),应该可以,有其它直接的方式吗?
上面这种方式一定要依赖symbol吗?

IP 地址: 已记录   报告
   2009-07-22, 00:32 上午
Thomson 离线,最后访问时间: 2013/3/31 11:42:42 Thomson

发帖数前10位
注册: 2008-07-03
发 贴: 211
Re: 如何在程序里面定位到其他进程的peb地址?
Reply Quote
应该从fs到TEB,到PEB就能找到...
不知道windbg里面的@$peb是不是这样求值的...
IP 地址: 已记录   报告
   2009-07-23, 12:45 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: 如何在程序里面定位到其他进程的peb地址?
Reply Quote
不太清楚楼主的用意。是为了开发一个调试器插件,还是用在一般的软件开发中?
从标题来看,是想得到其它进程的PEB地址,也就是从一个进程里取另一个进程的PEB,这有点像一个人想知道另一个人的钱包放在哪,呵呵,我的意思是说这是违反进程隔离理念的。

IP 地址: 已记录   报告
   2009-07-23, 14:05 下午
xqj2002zm 离线,最后访问时间: 2010/6/24 5:19:33 Alex.xu

发帖数前50位
注册: 2009-07-23
发 贴: 21
Re: 如何在程序里面定位到其他进程的peb地址?
Reply Quote
linux里面应该可以的。因为所有的进程是树形结构。可以遍历到init进程。然后再从init进程向下遍历所有的子进程。不知道试不试用与window下面。
IP 地址: 已记录   报告
   2009-07-23, 14:11 下午
Thomson 离线,最后访问时间: 2013/3/31 11:42:42 Thomson

发帖数前10位
注册: 2008-07-03
发 贴: 211
Re: 如何在程序里面定位到其他进程的peb地址?
Reply Quote
只是一个tool,基本上就是一个windbg的扩展,从target process的peb里面取得一些信息的..我在console app里面直接调用了dbgeng.dll,这样就不用依赖windbg相关的东西了.
IP 地址: 已记录   报告
高端调试 » 软件调试 » WinDbg » Re: 如何在程序里面定位到其他进程的peb地址?

 
Legal Notice Privacy Statement Corporate Governance Corporate Governance
(C)2004-2020 ADVDBG.ORG All Rights Reserved.