PHPLog php 程序調(diào)試追蹤工具
1.程序執(zhí)行的過程中,在相應(yīng)的地方記錄你想要追蹤的變量及調(diào)用棧和每次函數(shù)調(diào)用的參數(shù),
把這些信息以一定的格式記錄到文件,一個變量一行,具體數(shù)據(jù)格式請參看代碼,這里不細(xì)講.
2.現(xiàn)在有了每次記錄變量時的所有信息(包括調(diào)用棧及參數(shù)),當(dāng)你通過瀏覽器訪問這個程序時, 這個程序會把整個文件讀取分析,
在頁面顯示你的所有調(diào)試信息,并且它會動態(tài)ajax刷新,保持與你的調(diào)試同步.
畫個圖吧,要清晰得多.
BackTrace也就是調(diào)用棧信息,沒有在圖中體現(xiàn),是ajax動態(tài)刷新的.
功用:
再截幾個本機(jī)的圖說明下:
1.包含文件,調(diào)試變量(上面是程序,下面是apache_request_headers()的調(diào)試輸出)
2.drupal系統(tǒng)某次函數(shù)的調(diào)用棧列表
后記:
程序基本上實現(xiàn)了調(diào)試,追蹤php變量的功能,還附帶了調(diào)用棧及調(diào)用參數(shù)查看功能.
現(xiàn)在echo,print_r,var_dump等系統(tǒng)函數(shù),如非必要時,本人已很少用來調(diào)試輸出了,基本上用這個就可以得到想要的東西了.
特別是像drupal這類復(fù)雜的系統(tǒng),能夠清楚地知道程序是怎么執(zhí)行的.
說明:
程序是用php4的寫法寫成的,在php4.4.8, 5.2.5上測試過, 理論上是支持php4, php5的.
linux, window, ie6-7, firefox下也都測試過,但還是不敢保證在你的環(huán)境下不出錯,如有,請自行修正.
請不讓log文件超過5M大小,瀏覽器可能會崩潰的.
下載地址 http://www.dbjr.com.cn/codes/20851.html
相關(guān)文章

淺析PHP中的字符串編碼轉(zhuǎn)換(自動識別原編碼)

PHP防止sql注入小技巧之sql預(yù)處理原理與實現(xiàn)方法分析

PHP隨機(jī)生成隨機(jī)個數(shù)的字母組合示例

PHP實現(xiàn)找出鏈表中環(huán)的入口節(jié)點