直接或間接使用的所有 。它還會記錄「最後次 」至「
entry point 執行」之間的經過時間。此期間正是 Win32 載入器呼叫 implicitly loaded
DLLs 的初始化程式碼(程式進入點)的時間。最後,它允許使用者濾掉所有的 debug
event OutputDebugString … DBWIN !?
,只記錄被除錯端的 輸出的字串 這功能可不正是
使用真簡單,不是嗎!這程式若說還有什麼缺點,那就是「只有被此 DBWIN 載入之程
式,其 TRACE 輸出字串才能夠被觀察」。有洠в锌赡芟瘛 in16 的 DBWIN 那樣,做
個系統層面的 〃global〃 DBWIN ,像常駐程式那樣隨時偵測等候任何程式發出的任何
TRACE 字串呢?可能,但我們還要再層獄,進入 ring0 層次。
936
…………………………………………………………Page 999……………………………………………………………
附錄D 以MFC 重建DBWIN
CreateProcess(。。。DEBUG_ONLY_THIS_PROCESS。。。);
process A
。。。
TRACE(〃trace1 n〃);
TRACE(〃trace2 n〃);
TRACE(〃trace3 n〃);
。。。
OUTPUT_DEBUG_STRING_EVENT
LODPRF32 功能不少。若你把 〃OutputDebugString Only〃
那個圓鈕按,它就是個 DBWIN 。
圖九 LODPRF32 功能不少。若你把 〃OutputDebugString Only〃 那個圓
鈕按下,它就是個 DBWIN 。
重建 DBWIN 之VxD 篇
global DBWIN Ton Plooy
若想要寫個 ,困難度陡增。不過,已經有做出來了。請參考
發表於 Windows Developer"s Journal 1996。12 的 〃A DBWIN Utility for Win95〃 文。
前個 DBWIN 之所以不能夠做到 〃global〃 ,是因為行程有獨立的位址空間。如欲接收
除錯訊息,又必須建立「除錯器」與「被除錯端」的關係。那麼,有洠в惺颤N辦法
可以建立個「系統除錯器」,把所有執行起來的程式統統視為我的除錯對象?如果這
個問睿锌隙ù鸢福琯lobal DBWIN 就有希望了。
有,VMM 提供了個 INT 41h 介面。此介面作用起來的條件是,必須有個「系統除
錯器」存在。而「系統除錯器」存在的條件是:當 VMM 以int41h/AX=DS_DebLoaded 發
出訊息時,必須有程式以 AX=DS_DebPresent 回覆之。
可是 OutputDebugString 和「系統除錯器」有洠в惺颤N牽連?如果洠в袆t切白搭。幸
叩氖恰 utputDebugString 最終會牽動 VMM 的 Exec_PM_Int41h service 。如果我們能
937
…………………………………………………………Page 1000……………………………………………………………
第五篇 附錄
Exec_PM_Int41h Exec PM Int41h
hooking _ _
夠寫個程式,與 掛勾( ),使 能夠先來呼
叫我自己的函式,我就可以悠游自在在其處理TRACE 的除錯字串了。
這個技術最大的難點在於,要與 VMM 打交道,我們得寫 ring0 程式。在 Windows 95
VxD NT VxD VxD DOS/Windows 虛虛
這意味著要寫 ( 不支援 )。 的架構其實不太難, 虛虛
擬機器作業環境擬機器作業環境 / 1993 VMM
擬機器作業環境擬機器作業環境 (侯俊傑 旗標, )曾經有過詳細的探討。問睿陟丁 〉脑S
多 services 常常要合著用,尤其是面對斷模擬、事件處理、與 ring3 通訊過程、乃至
於 hooking 的處理等等,而這方面的資料與範例相當稀少。此外,ring0 和 ring3 間的
同步(synchronous )處理,也很令頭痛。
process A
global DBWIN
。。。
TRACE(〃JJHOU n〃);
TRACE(〃MikeSon n〃);
TRACE(〃Matt n〃);
。。。
process B
。。。
TRACE(〃trace1 n〃);
小说推荐
- Java编程思想第4版[中文版](PDF格式)
- -Page 1-Page 2《Thinking In Java》中文版作者:Bruce Eckel主页:http/BruceEckel.编译:Trans Bot主页:http/memberease~transbot致谢-献给那些直到现在仍在孜孜不倦创造下一代计算机语言的人们!指导您利用万维网的语言进
- 最新章:第295章
- VB2008从入门到精通(PDF格式英文版)
- -Page 1(R)The eXperT’s Voice inBeginningVB 2008From Novice to ProfessionalChristian Gross-Page 2-Page 3-Beginning VB 2008From Novice to Professional■C
- 最新章:第214章
- oracle从入门到精通(PDF格式)
- -Page 1-Oracle 从入门到精通-Page 2-资源来自网络,仅供学习 Oracle 从入门到精通一、SQL 8
- 最新章:第37章
- C语言游戏编程从入门到精通(PDF格式)
- -Page 1-Page 2-Page 3-Page 4-Page 5-Page 6-Page 7-Page 8-Page 9-Page 10-Page 11-Page 12-Page 13-Page 14
- 最新章:第4章
- 深入浅出
- 《深入浅出》作者:白小骨晋江VIP20140610完结+1番外非V章节总点击数:67370 总书评数:209 当前被收藏数:764 文章积分:11,386,657文案:每个前男友都是女人掉过的坑,从何典阳这个坑里往外爬的梁温暖一脸血表示,何典阳他这个深坑实在太坑爹。何典阳:我是坑?梁温暖…别看我,我
- 最新章:第74章
- 深入浅出[娱乐圈]
- 文案【忠犬影帝攻X傲娇明星受,1V1轻松甜文,前期互相试探,38章在一起后甜甜甜,两人都有细微的变化和成长~这也是我用心构思攻受感情发展的文,但数据有点太惨了,没入V可以全文免费看,还是想求点收藏呀,数据好看点吧,让我开心一下(笑哭.jpg)流量偶像白漾和影帝顾瑜祁关系很僵,传言两人出道时不合而互相
- 最新章:第59章
- JMS简明教程(PDF格式)
- -Page 1-JMS1.1规范中文版卫建军2007‐11‐22-Page 2
- 最新章:第28章
- SQL语言艺术(PDF格式)
- -Page 1-SQLSSQQLL语言艺术内容介绍本书分为12章,每一章包含许多原则或准则,并通过举例的方式对原则进行解释说明。这些例子大多来自于实际案例,对九种SQL经典查询场景以及其性能影响讨论,非常便于实践,为你数据库应用维护人员阅读。资深 SQL 专家 Stéphane Faroult倾力打
- 最新章:第27章
- C语言实例教程(PDF格式)
- -Page 1-前 言Visual C+是开发运行于Windows 95和Windows NT环境下的Win32应用程序的可视化编程工具中最重要的成员之一,它为软件开发人员提供了完整的编辑、编译和调试工具和建立于Win32 API(ApplicationProgramming Interface)基
- 最新章:第143章