上次我們提到,沒有源代碼而且沒有調(diào)試符號,我們也可以 Debug。有人可能會問,我什么時候需要在這種情況下調(diào)試嗎?!

是的。比方說,我們用了某些第三方的組件,這些組件里面難免也會有 Bug。就算是微軟發(fā)布的 .net 組件,我們在某些個別的例子中發(fā)現(xiàn)了 Bug。就算這些人家的組件都沒有問題,有時候我們也不得不在程序運行到組件中的某些語句時候查看一些數(shù)據(jù)。

舉個栗子:我們的程序用了某個組件A。當用戶鼠標單擊A的一個窗口的時候,A的某個方法應該回掉我們的一個方法??墒撬谷粵]有(我們在自己的方法上加了斷點,沒有被擊中)!如果我們在這個時候能夠給組件中點擊事件的處理函數(shù)加上斷點,我們就可以探一探究竟了。

下面我們就從易到難來看看如何調(diào)試別人家的組件。

我們先來看如何調(diào)試 .NET Framework 的組件。

1. 我們對 VS 的 Options -> Debugging -> General 做一些配置,如下圖:

大學生就業(yè)培訓,高中生培訓,在職人員轉(zhuǎn)行培訓,企業(yè)團訓

大學生就業(yè)培訓,高中生培訓,在職人員轉(zhuǎn)行培訓,企業(yè)團訓

2. 我們要緩存 .NET 的調(diào)試符號, 到 Options -> Debugging -> Symbols, 設置 Cache symbols in this directory 到一個本地的路徑。

配置完成,我們來做個實驗。我們知道每個 WPF 的窗口的構(gòu)造函數(shù)內(nèi)都會調(diào)用一個 InitializeComponent() 方法。我們今天想看看這個方法它到底干了什么?;谝陨蟽牲c配置,我們新建一個 WPF 程序,然后給這個方法設斷點,當程序運行到該語句時,我們點擊F11,哈,我們就進入了微軟的代碼,請看:

大學生就業(yè)培訓,高中生培訓,在職人員轉(zhuǎn)行培訓,企業(yè)團訓

大學生就業(yè)培訓,高中生培訓,在職人員轉(zhuǎn)行培訓,企業(yè)團訓

是不是感覺很酷?

調(diào)試第三方的組件

這個我們要分幾種情況來看:

A. 第三方提供了調(diào)試符號

這種情況最簡單?;谖覀円陨系脑O置,我們只需要把調(diào)試符號放到這些組建相同的目錄下即可。放到別處也可以,我們需要 VS 的 Options -> Debugging -> Symbols 添加一個新的 Symbol file location,然后開始我們的調(diào)試。

B. 第三方?jīng)]有提供調(diào)試符號,但代碼發(fā)布時沒有擾碼

這種情況也比較好辦。市場上有很多的反編譯工具,免費的就有不少比方說 JustDecompile,dotPeek 等。他們不僅能反編譯,還能產(chǎn)生調(diào)試符號,以便我們進行調(diào)試。舉個例子,我用 JustDecompile 打開了 log4net.dll(請點擊 Generate PDB):

大學生就業(yè)培訓,高中生培訓,在職人員轉(zhuǎn)行培訓,企業(yè)團訓

大學生就業(yè)培訓,高中生培訓,在職人員轉(zhuǎn)行培訓,企業(yè)團訓

有了調(diào)試符號,我們要做的就跟情況A一樣了。

C. 第三方?jīng)]有提供調(diào)試符號,但代碼發(fā)布時擾碼了

這種情況比較難辦。我們的目標還是一樣的,需要有沒有擾碼的組件及調(diào)試符號。余下的都是一樣的。市場上有沒有反擾碼的工具呢?有,還有開源的呢。今天就告訴大家一個,名叫 de4dot,這個項目在 GitHub 的地址是:https://github.com/0xd4d/de4dot. 通過這個工具,我們可以把擾碼后生成的組件變成非擾碼的組建。剩下的還要做什么,相信大家都知道了吧(參考情況B)?
可惜的是,對于深度擾碼的組件,我們就需要更高級的反擾碼工具。當然,我們也不需要這么做。情況C我們只會在極端情況下才會面對,對吧?

哈哈,今天就到這里啦!

 


網(wǎng)友評論