轉自:http://www.ibm.com/developerworks/cn/opensource/os-debug/ 使用 print 語句、錯誤報告和 PHPEclipse 插件 ![]() |
![]() |
![]() |
級別: 中級 Tyler Anderson (tyleranderson5@yahoo.com), 自由作者 2006 年 1 月 23 日 本 文介紹調試 PHP 應用程序的各種方法,包括在 Apache and PHP 中打開錯誤報告,以及通過在一個簡單的 PHP 腳本中放置策略性的 print 語句,找到更困難的 bug 的源頭。還會介紹用于 Eclipse 的 PHPEclipse 插件,這是一個靈活的開發環境,具有實時語法解析能力,還會介紹 PHPEclipse 的 DBG 調試器擴展。 有許多 PHP 調試技術可以在編碼的時候節約大量時間。一個有效卻很基本的調試技術就是打開錯誤報告。另一個略微高級一點的技術包括使用 print 語句,通過顯示在屏幕上實際出現的內容,有助于精確地找出更難發現的 bug。PHPEclipse 是一個 Eclipse 插件,能夠強調常見的語法錯誤,可以與調試器結合起來用于設置斷點。
要學習本文描述的概念,需要 PHP、Web 服務器和 Eclipse。調試器擴展支持的 PHP 版本是 V5.0.3。 我們需要一個 Web 服務器來解析用 PHP 創建的頁面并把它們顯示到瀏覽器。本文中使用的是 Apache2。但是,任何 Web 服務器都可以滿足要求。 要利用本文中介紹的一些調試技術,需要安裝 Eclipse V3.1.1 和插件 PHPEclipse V1.1.8。由于 Eclipse 要求 Java™ 技術,所以還要下載它。 還需要 PHP 的調試器擴展模塊。安裝它略有些麻煩。請仔細跟隨安裝調試器擴展的操作說明。現在,先在 php.ini 文件中注釋掉那些要求裝入和配置 PHP 擴展的行。在需要使用調試器的時候,再取消注釋。 請參閱 參考資料 獲得下載信息。現在介紹出錯消息。
出錯消息是作為開發人員的第一道防線。誰都不想在一臺沒有配置成顯示出錯消息的服務器上用 PHP 開發代碼。但是,請記住,當代碼調試完成,準備運行的時候,應當確保關閉了錯誤報告,因為不希望站點的訪問者看到出錯消息,因為這會給他們提供足夠的信息 來利用站點的弱點并黑掉站點。 也可以用出錯消息為自己服務,因為它們會顯示拋出或生成錯誤的正確代碼行。這樣,調試就變成在瀏覽器上查看生成的錯誤所顯示的行號,并在代碼中檢查 這一行。稍后,將會看到 PHPEclipse 插件通過即時地給語法錯誤加下劃線并在保存文件時用紅色 “x” 標注語法錯誤,可在開發和調試過程中提供極大的幫助。 先來看如何在 php.ini 文件中開啟錯誤報告并設置錯誤報告的級別。然后將學習如何在 Apache 的配置文件中覆蓋這些設置。 php.ini 文件中有許多配置設置。您應當已經設置好自己的 php.ini 文件并把它放在合適的目錄中,就像在 Linux 上安裝 PHP 和 Apache 2 的文檔說明中所示的那樣(請參閱 參考資料)。在調試 PHP 應用程序時,應當知道兩個配置變量。下面是這兩個變量及其默認值:
通過在 php.ini 文件中搜索它們,可以發現這兩個變量當前的默認值。
重新啟動 Apache,就全部設置好了。接下來,將學習如何在 Apache 上做同樣的事。 依賴于 Apache 正在做的工作,在 PHP 中打開錯誤報告可能沒法工作,因為在計算機上可能有多個 PHP 版本。有時很難區分 Apache 正在使用哪個 PHP 版本,因為 Apache 只能查看一個 php.ini 文件。不知道 Apache 正在使用哪個 php.ini 文件配置自己是一個安全問題。但是,有一種方法可以在 Apache 中配置 PHP 變量,從而保證設置了正確的出錯級別。 而且,最好知道如何在服務器端設置這些配置變量,以否決或搶占 php.ini 文件,從而提供更高級別的安全性。 在配置 Apache 時,應該已經接觸過 <apache2-install-dir>/conf/httpd.conf 中 http.conf 文件中的基本配置。 要做在 php.ini 文件中已經做過的事,請把下列各行添加到 httpd.conf,覆蓋任何 php.ini 文件:
這會覆蓋在 php.ini 文件中為 接下來,要在服務器上測試錯誤報告。 如果啟動了錯誤報告,會節約許多時間。PHP 中的錯誤會指向代碼中的錯誤。請創建一個簡單的 PHP 文件 test.php,并像清單 1 所示一樣定義它。 清單 1. 一個生成錯誤的簡單 PHP
第一個 圖 1. 生成錯誤 ![]() 現在開啟了錯誤報告!接下來,用 print 語句幫助調試應用程序。
因為應用程序中的功能性 bug 不會產生錯誤,所以在所有調試策略中,關于如何正確地放置和使用 假設正在處理通過
讓我們在 PHP 中用 print 語句來測試這個概念 在我作程序員的那些時候,當我在 Linux® 上開發應用程序時,沒有方便的 GUI 可以告訴我 bug 在哪,我迅速地發現我在程序中放的 print 語句越多,我在應用程序中把 bug 的范圍縮小到一行的機會越大。請創建另一個 PHP 文件 test2.php,并像清單 2 所示的那樣定義它。 清單 2. 顯示通過 GET 提交的所有變量
您可能會非常容易地發現清單 2 中的 bug!您很棒!但請注意這是一個非常簡單的腳本,只是作為使用 print 語句進行調試而展示的一個例子而已。這個腳本只是提取 圖 2. test2.php 的輸出 ![]() 現在單擊 Send GET Request 按鈕,請注意只有 清單 3. 用 print 語句驗證代碼的功能
放進去的 print 語句是粗體。注意,現在已經知道在 Web 瀏覽器上顯示的 圖 3. 修改后的 test2.php 的輸出 ![]() 現在已經知道應用程序正確地從 圖 4. 修正后的 test2.php 的輸出 ![]() 現在可以刪除或注釋掉剛才添加的 print 語句了,因為已經發現了代碼中的 bug。注意,這只是在調試應用程序時可能遇到的許多錯誤中的一個很小的子集。對于使用數據庫時可能遇到的問題,一個好的解決方案是輸出 SQL 語句,以確保執行的 SQL 就是想要執行的。 現在要來看看如何使用 Eclipse IDE 和 PHPEclipse 插件及調試器擴展進一步在調試歷程中提供幫助。
您可能用過 Eclipse,但是可能不熟悉它。請參閱 參考資料 獲得 Eclipse 平臺的介紹。 用于 Eclipse 的 PHPEclipse 插件是用來開發 PHP 應用程序的一個流行工具。請啟動 Eclipse 并把工作區目錄指定為 Apache 的 www 目錄(在我的機器上是 c:"www)。現在單擊 File > New > Project。會彈出 New Project 向導。雙擊 PHP 文件夾并選擇 PHP Project。單擊 Next,輸入項目名稱 debugArticle,并單擊 Finish。 如果把 Web 服務器設置為在端口 80 上偵聽,那么不需要做任何修改。否則,請轉到 Navigator 窗口,在 PHP 項目 debugArticle 上右擊,選擇 Properties,然后單擊 PHP Project Settings。單擊 Configure Workspace Settings 然后修改合適的 localhost 或者添加 Web 服務器偵聽的端口(例如 http://localhost:8080)。單擊 Apply 完成設置。 Navigator 窗口應當顯示項目和一個 .project 文件。在項目上右擊,就像前面做的那樣,只是這次選擇 New > PHP File。用想要創建的 PHP 文件的名稱 test3.php 替換 *.php,然后單擊 Finish。在 Eclipse IDE 中應當出現一個新文件。可能需要導航到窗口底部的 PHP 瀏覽器來查看 PHP 文件的當前輸出(參見圖 5)。 圖 5. Eclipse 的 PHPEclipse 插件 ![]() 注意,只有 Windows® 的用戶可以像清單 5 所示的那樣使用 PHP 瀏覽器。通過打開獨立瀏覽器窗口并把瀏覽器指向測試腳本所在目錄,也可以使用同樣的功能。 現在來演示這個應用程序,證明它的強大能力。 在 “使用調試器” 一節中,將學習如何用 Eclipse、PHPEclipse 和前面下載的調試器 PHP 擴展來調試 PHP 應用程序。先從學習如何使用它的語法解析功能開始。 先從查看 PHPEclipse 如何提供幫助調試 PHP 應用程序的實時語法解析功能開始。要看這個特性的實際應用,先從在 Eclipse 中定義 test3.php 開始,如下所示。
注意,在清單 4 中加下劃線的兩個字符在 Eclipse 中加了下劃線,提示語法不正確。按 Ctrl+S 保存文件,會在 Eclipse 中顯示解析錯誤:在代碼中與解析錯誤對應的行上會加上紅 “x”,如圖 6 所示。 圖 6. 語法錯誤強調 ![]() 現在演示 PHP 瀏覽器。這個窗口提供了當前 PHP 腳本的預覽,如圖 6 所示。 從上面定義的 test3.php 中刪除逗號( 圖 7. 在 PHPEclipse 中預覽 PHP 腳本 ![]() 下面是用調試器在 PHP 中設置斷點。
使用調試器,可以設置斷點并查看 PHP 代碼到所設斷點之前的瀏覽器輸出。然后可以繼續代碼的執行并查看到下一斷點之前的瀏覽器輸出,然后再到下一個,直到 PHP 腳本完成。 現在把 “設置” 一節中在 php.ini 中注釋掉的行取消注釋,并重新啟動 Apache。現在裝入了調試器,Eclipse 能夠和它掛上了。 現在在 Eclipse 中設計調試環境。請創建新的 test4.php 文件,先保持為空。現在單擊 Run > Debug。在左側面板中選擇 PHP DBG Script,并單擊 New。現在轉到 File 選項卡,輸入當前項目 debugArticle 以及想要調試的文件 test4.php。現在轉到 Environment 選項卡,然后再到 Interpreter 子選項卡。在 PHP 的安裝目錄中找到 php.exe 文件(我的是 c:"apps"php5.0.3"php.exe)。現在單擊 Remote Debug 子選項卡,選擇 Remote Debug, 如果沒有使用 Windows,請取消 “Open with DBGSession URL in internal browser box” 復選框。把 Remote Source 路徑設置成與要測試的 PHP 腳本的絕對路徑(不是 Web 路徑)相同(我的設置是 c:"www"debugArticle"test4.php)。 現在單擊 Debug。 現在應當裝入 Debug 透視圖,如圖 8 所示。否則,請單擊 Window > Open Perspective > Other,并選擇 Debug。 圖 8. Eclipse 中的 Debug 透視圖 ![]() 現在可以設置斷點了。 對于本文中使用的插件和擴展的版本,斷點功能是必需的,因為 PHP 在把輸出發送到瀏覽器之前會緩沖它。除此之外,需要做的不僅僅是設置一個斷點把當前顯示數據刷新到 Web 瀏覽器,所以要像下面和圖 8 所示那樣定義 test4.php。 清單 4. 設置和創建斷點
在像清單 4 那樣編寫完代碼之后,可以打開瀏覽器并指向 test4.php,或者可以查看 PHP 瀏覽器窗口(我的是
http://localhost/debugArticle/test4.php)。每次輸入和保存文件時,在 PHP
瀏覽器窗口中就已經啟動了調試序列。如果不使用 Windows,請通過瀏覽器查看 test4.php。在保存了文件之后,用 F8 或單擊 Run > Resume 繼續代碼執行。持續這么做,直到最后一行輸出是 圖 9. 初始的到第一個斷點的 PHP 瀏覽器輸出 ![]() 請注意圖 9 中的 Debug 窗口如何把執行顯示為掛起的。 圖 10. 第一個斷點之后到第二個斷點之前的 PHP 瀏覽器輸出 ![]() 圖 10 的 Debug 窗口仍然把執行顯示為掛起,而第二組數據顯示在 PHP 瀏覽器中。 圖 11. 完整的 PHP 瀏覽器輸出 ![]() 注意,圖 11 的 Debug 窗口中的代碼不再掛起,整個腳本已經執行,如圖 11 中的 PHP 瀏覽器所示。 既然已經看到了用 PHPEclipse 和調試器擴展進行開發的優勢,那么很難想像沒有它會怎么樣。
現在已經向 PHP 的調試技術集中添加了錯誤報告的運用、print 語句、PHPEclipse 和調試器擴展,您可以通過減少每行代碼的錯誤數量,成為更有效的 PHP 編碼人員。請參閱 參考資料 獲得一些 PHP 教程,可以在上面測試這些新技能。
學習
獲得產品和技術
討論
|