亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1033 | 回復(fù): 0
打印 上一主題 下一主題

PHP程序員的優(yōu)化調(diào)試技術(shù)和技巧(一) [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2007-08-21 15:54 |只看該作者 |倒序?yàn)g覽
本文介紹調(diào)試 PHP 應(yīng)用程序的各種方法,包括在 Apache and PHP 中打開錯誤報(bào)告,以及通過在一個簡單的 PHP 腳本中放置策略性的 print 語句,找到更困難的 bug 的源頭。還會介紹用于 Eclipse 的 PHPEclipse 插件,這是一個靈活的開發(fā)環(huán)境,具有實(shí)時語法解析能力,還會介紹 PHPEclipse 的 DBG 調(diào)試器擴(kuò)展。
  簡介
  有許多 PHP 調(diào)試技術(shù)可以在編碼的時候節(jié)約大量時間。一個有效卻很基本的調(diào)試技術(shù)就是打開錯誤報(bào)告。另一個略微高級一點(diǎn)的技術(shù)包括使用 print 語句,通過顯示在屏幕上實(shí)際出現(xiàn)的內(nèi)容,有助于精確地找出更難發(fā)現(xiàn)的 bug。PHPEclipse 是一個 Eclipse 插件,能夠強(qiáng)調(diào)常見的語法錯誤,可以與調(diào)試器結(jié)合起來用于設(shè)置斷點(diǎn)。
  設(shè)置
  要學(xué)習(xí)本文描述的概念,需要 PHP、Web 服務(wù)器和 Eclipse。調(diào)試器擴(kuò)展支持的 PHP 版本是 V5.0.3。
  我們需要一個 Web 服務(wù)器來解析用 PHP 創(chuàng)建的頁面并把它們顯示到瀏覽器。本文中使用的是 Apache2。但是,任何 Web 服務(wù)器都可以滿足要求。
  要利用本文中介紹的一些調(diào)試技術(shù),需要安裝 Eclipse V3.1.1 和插件 PHPEclipse V1.1.8。由于 Eclipse 要求 Java? 技術(shù),所以還要下載它。
  還需要 PHP 的調(diào)試器擴(kuò)展模塊。安裝它略有些麻煩。請仔細(xì)跟隨安裝調(diào)試器擴(kuò)展的操作說明,F(xiàn)在,先在 php.ini 文件中注釋掉那些要求裝入和配置 PHP 擴(kuò)展的行。在需要使用調(diào)試器的時候,再取消注釋。
  請參閱
參考資料
獲得下載信息,F(xiàn)在介紹出錯消息。
  出錯消息
  出錯消息是作為開發(fā)人員的第一道防線。誰都不想在一臺沒有配置成顯示出錯消息的服務(wù)器上用 PHP 開發(fā)代碼。但是,請記住,當(dāng)代碼調(diào)試完成,準(zhǔn)備運(yùn)行的時候,應(yīng)當(dāng)確保關(guān)閉了錯誤報(bào)告,因?yàn)椴幌M军c(diǎn)的訪問者看到出錯消息,因?yàn)檫@會給他們提供足夠的信息來利用站點(diǎn)的弱點(diǎn)并黑掉站點(diǎn)。
  也可以用出錯消息為自己服務(wù),因?yàn)樗鼈儠@示拋出或生成錯誤的正確代碼行。這樣,調(diào)試就變成在瀏覽器上查看生成的錯誤所顯示的行號,并在代碼中檢查這一行。稍后,將會看到 PHPEclipse 插件通過即時地給語法錯誤加下劃線并在保存文件時用紅色 “x” 標(biāo)注語法錯誤,可在開發(fā)和調(diào)試過程中提供極大的幫助。
  先來看如何在 php.ini 文件中開啟錯誤報(bào)告并設(shè)置錯誤報(bào)告的級別。然后將學(xué)習(xí)如何在 Apache 的配置文件中覆蓋這些設(shè)置。
  PHP 的錯誤報(bào)告
  php.ini 文件中有許多配置設(shè)置。您應(yīng)當(dāng)已經(jīng)設(shè)置好自己的 php.ini 文件并把它放在合適的目錄中,就像在 Linux 上安裝 PHP 和 Apache 2 的文檔說明中所示的那樣(請參閱
參考資料
)。在調(diào)試 PHP 應(yīng)用程序時,應(yīng)當(dāng)知道兩個配置變量。下面是這兩個變量及其默認(rèn)值:

display_errors = Off
error_reporting = E_ALL
  通過在 php.ini 文件中搜索它們,可以發(fā)現(xiàn)這兩個變量當(dāng)前的默認(rèn)值。display_errors 變量的目的很明顯 —— 它告訴 PHP 是否顯示錯誤。默認(rèn)值是 Off。但是,要讓開發(fā)過程更加輕松,請把這個值設(shè)為 On:

display_errors = On
  error_reporting 變量的默認(rèn)值是 E_ALL。這個設(shè)置會顯示從不良編碼實(shí)踐到無害提示到出錯的所有信息。E_ALL 對于開發(fā)過程來說有點(diǎn)太細(xì),因?yàn)樗谄聊簧蠟橐恍┬∈拢ɡ缱兞课闯跏蓟┮诧@示提示,會搞糟瀏覽器的輸出。我只想看到錯誤和不良編碼實(shí)踐,但是不想看到無害的提示。所以,請用以下值代替 error_reporting 的默認(rèn)值:

error_reporting = E_ALL & ~E_NOTICE
  重新啟動 Apache,就全部設(shè)置好了。接下來,將學(xué)習(xí)如何在 Apache 上做同樣的事。
  服務(wù)器上的錯誤報(bào)告
  依賴于 Apache 正在做的工作,在 PHP 中打開錯誤報(bào)告可能沒法工作,因?yàn)樵谟?jì)算機(jī)上可能有多個 PHP 版本。有時很難區(qū)分 Apache 正在使用哪個 PHP 版本,因?yàn)?Apache 只能查看一個 php.ini 文件。不知道 Apache 正在使用哪個 php.ini 文件配置自己是一個安全問題。但是,有一種方法可以在 Apache 中配置 PHP 變量,從而保證設(shè)置了正確的出錯級別。
  而且,最好知道如何在服務(wù)器端設(shè)置這些配置變量,以否決或搶占 php.ini 文件,從而提供更高級別的安全性。
  在配置 Apache 時,應(yīng)該已經(jīng)接觸過 /conf/httpd.conf 中 http.conf 文件中的基本配置。
  要做在 php.ini 文件中已經(jīng)做過的事,請把下列各行添加到 httpd.conf,覆蓋任何 php.ini 文件:

php_flag  display_errors        on
php_value error_reporting       2039
  這會覆蓋在 php.ini 文件中為 display_errors 已經(jīng)設(shè)置的標(biāo)志,以及 error_reporting 的值。值 2039 代表 E_ALL & ~E_NOTICE。如果愿意采用 E_ALL,請把值設(shè)為 2047。同樣,還是要重啟 Apache。
  接下來,要在服務(wù)器上測試錯誤報(bào)告。
  測試錯誤報(bào)告
  如果啟動了錯誤報(bào)告,會節(jié)約許多時間。PHP 中的錯誤會指向代碼中的錯誤。請創(chuàng)建一個簡單的 PHP 文件 test.php,并像清單 1 所示一樣定義它。
清單 1. 一個生成錯誤的簡單 PHP


  第一個 print() 語句會向 Web 瀏覽器顯示它的內(nèi)容。但是第二個語句會生成錯誤并在 Web 頁面上顯示。這造成最后一個 print() 語句不起作用,如圖 1 所示。
圖 1. 生成錯誤

  現(xiàn)在開啟了錯誤報(bào)告!接下來,用 print 語句幫助調(diào)試應(yīng)用程序。
  介紹 print 語句
  因?yàn)閼?yīng)用程序中的功能性 bug 不會產(chǎn)生錯誤,所以在所有調(diào)試策略中,關(guān)于如何正確地放置和使用 print 或 die 語句來調(diào)試 PHP 應(yīng)用程序的知識是一種很好的資產(chǎn)?梢杂 print 語句在代碼中縮小對問題語句的定位,這些語句在語法上沒有錯誤,也不是 bug,但是從代碼的功能上看是 bug。這些是最難發(fā)現(xiàn)和調(diào)試的 bug,因?yàn)樗鼈儾粫䲣伋鲥e誤。惟一知道的就是在瀏覽器上顯示的內(nèi)容不是想要的內(nèi)容,或者想要保存在數(shù)據(jù)庫中的內(nèi)容根本沒有保存。
  假設(shè)正在處理通過 GET 請求發(fā)送過來的表單數(shù)據(jù),想向?yàn)g覽器顯示信息,但是出于某種原因,數(shù)據(jù)沒有正確地提交,或者不能正確地從 GET 請求中讀出。要調(diào)試這類問題,重要的是用 print() 或 die() 語句知道變量的值是什么。
  die() 語句會中止程序執(zhí)行,并在 Web 瀏覽器上顯示文本。如果不想注釋掉代碼,而且只想顯示到出錯之前的信息和出錯信息,不想顯示后面的信息,那么 die() 語句特別有用。
  讓我們在 PHP 中用 print 語句來測試這個概念
  使用 print 語句進(jìn)行調(diào)試
  在我作程序員的那些時候,當(dāng)我在 Linux? 上開發(fā)應(yīng)用程序時,沒有方便的 GUI 可以告訴我 bug 在哪,我迅速地發(fā)現(xiàn)我在程序中放的 print 語句越多,我在應(yīng)用程序中把 bug 的范圍縮小到一行的機(jī)會越大。請創(chuàng)建另一個 PHP 文件 test2.php,并像清單 2 所示的那樣定義它。
清單 2. 顯示通過 GET 提交的所有變量

$i){
     print("$key=$j
");
}
if($_GET['Submit'] == "Send GET Request")
     $j = "done!
";
?>

     Name:

     Email:

      

  您可能會非常容易地發(fā)現(xiàn)清單 2 中的 bug!您很棒!但請注意這是一個非常簡單的腳本,只是作為使用 print 語句進(jìn)行調(diào)試而展示的一個例子而已。這個腳本只是提取 GET 請求中的所有變量,如果有,就把它們顯示在瀏覽器上。還提供了一個表單,用 GET 請求向服務(wù)器發(fā)送變量以進(jìn)行測試。請看輸出,如圖 2 所示。
圖 2. test2.php 的輸出

  現(xiàn)在單擊 Send GET Request 按鈕,請注意只有 $_GET 請求的鍵顯示在瀏覽器上,而正確的值都沒顯示?梢栽谘h(huán)中放一個 print 語句,檢驗(yàn)在 foreach 循環(huán)中每個元素中是否確實(shí)存在數(shù)據(jù)。請參閱清單 3。
清單 3. 用 print 語句驗(yàn)證代碼的功能

...
foreach($_GET as $key => $i){
     print("Correct data? " . $_GET[$key] . "
");
     print("$key=$j
");
}
...
  放進(jìn)去的 print 語句是粗體。注意,現(xiàn)在已經(jīng)知道在 Web 瀏覽器上顯示的 $key 值是正確的,但是由于某些原因,值沒有正確地顯示。請看新的輸出,如圖 3 所示。
圖 3. 修改后的 test2.php 的輸出

  現(xiàn)在已經(jīng)知道應(yīng)用程序正確地從 GET 請求接收到了變量,那么肯定是在代碼中有 bug。查看之后注意到,用來顯示值的變量 $j 是錯誤的。在 foreach 語句中指定的是 $i,所以它肯定會有正確的值,但是無意之中輸入了 $j。所以通過把 $j 替換成 $i,迅速地修正了錯誤,重新載入頁面之后,就看到了正確的輸出,如圖 4 所示。
圖 4. 修正后的 test2.php 的輸出

  現(xiàn)在可以刪除或注釋掉剛才添加的 print 語句了,因?yàn)橐呀?jīng)發(fā)現(xiàn)了代碼中的 bug。注意,這只是在調(diào)試應(yīng)用程序時可能遇到的許多錯誤中的一個很小的子集。對于使用數(shù)據(jù)庫時可能遇到的問題,一個好的解決方案是輸出 SQL 語句,以確保執(zhí)行的 SQL 就是想要執(zhí)行的。
  現(xiàn)在要來看看如何使用 Eclipse IDE 和 PHPEclipse 插件及調(diào)試器擴(kuò)展進(jìn)一步在調(diào)試歷程中提供幫助。
使用 PHPEclipse
  您可能用過 Eclipse,但是可能不熟悉它。請參閱 參考資料 獲得 Eclipse 平臺的介紹。
  用于 Eclipse 的 PHPEclipse 插件是用來開發(fā) PHP 應(yīng)用程序的一個流行工具。請啟動 Eclipse 并把工作區(qū)目錄指定為 Apache 的 www 目錄(在我的機(jī)器上是 c:\www),F(xiàn)在單擊 File > New > Project。會彈出 New Project 向?qū)。雙擊 PHP 文件夾并選擇 PHP Project。單擊 Next,輸入項(xiàng)目名稱 debugArticle,并單擊 Finish。
  如果把 Web 服務(wù)器設(shè)置為在端口 80 上偵聽,那么不需要做任何修改。否則,請轉(zhuǎn)到 Navigator 窗口,在 PHP 項(xiàng)目 debugArticle 上右擊,選擇 Properties,然后單擊 PHP Project Settings。單擊 Configure Workspace Settings 然后修改合適的 localhost 或者添加 Web 服務(wù)器偵聽的端口(例如 http://localhost:8080)。單擊 Apply 完成設(shè)置。
  Navigator 窗口應(yīng)當(dāng)顯示項(xiàng)目和一個 .project 文件。在項(xiàng)目上右擊,就像前面做的那樣,只是這次選擇 New > PHP File。用想要創(chuàng)建的 PHP 文件的名稱 test3.php 替換 *.php,然后單擊 Finish。在 Eclipse IDE 中應(yīng)當(dāng)出現(xiàn)一個新文件?赡苄枰獙(dǎo)航到窗口底部的 PHP 瀏覽器來查看 PHP 文件的當(dāng)前輸出(參見圖 5)。
圖 5. Eclipse 的 PHPEclipse 插件

  注意,只有 Windows? 的用戶可以像清單 5 所示的那樣使用 PHP 瀏覽器。通過打開獨(dú)立瀏覽器窗口并把瀏覽器指向測試腳本所在目錄,也可以使用同樣的功能。
  現(xiàn)在來演示這個應(yīng)用程序,證明它的強(qiáng)大能力。
  在 “使用調(diào)試器” 一節(jié)中,將學(xué)習(xí)如何用 Eclipse、PHPEclipse 和前面下載的調(diào)試器 PHP 擴(kuò)展來調(diào)試 PHP 應(yīng)用程序。先從學(xué)習(xí)如何使用它的語法解析功能開始。
  語法解析和加下劃線
  先從查看 PHPEclipse 如何提供幫助調(diào)試 PHP 應(yīng)用程序的實(shí)時語法解析功能開始。要看這個特性的實(shí)際應(yīng)用,先從在 Eclipse 中定義 test3.php 開始,如下所示。


  注意,在清單 4 中加下劃線的兩個字符在 Eclipse 中加了下劃線,提示語法不正確。按 Ctrl+S 保存文件,會在 Eclipse 中顯示解析錯誤:在代碼中與解析錯誤對應(yīng)的行上會加上紅 “x”,如圖 6 所示。


本文來自ChinaUnix博客,如果查看原文請點(diǎn):http://blog.chinaunix.net/u/30002/showart_364721.html
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP