亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

PHP程序員的優化調試技術和技巧

2024-09-04 11:50:09
字體:
來源:轉載
供稿:網友
本文介紹調試 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 的調試器擴展模塊。安裝它略有些麻煩。請仔細跟隨安裝調試器擴展的操作說明?,F在,先在 php.ini 文件中注釋掉那些要求裝入和配置 PHP 擴展的行。在需要使用調試器的時候,再取消注釋。

  請參閱 參考資料 獲得下載信息。現在介紹出錯消息。

  出錯消息

  出錯消息是作為開發人員的第一道防線。誰都不想在一臺沒有配置成顯示出錯消息的服務器上用 PHP 開發代碼。但是,請記住,當代碼調試完成,準備運行的時候,應當確保關閉了錯誤報告,因為不希望站點的訪問者看到出錯消息,因為這會給他們提供足夠的信息來利用站點的弱點并黑掉站點。

  也可以用出錯消息為自己服務,因為它們會顯示拋出或生成錯誤的正確代碼行。這樣,調試就變成在瀏覽器上查看生成的錯誤所顯示的行號,并在代碼中檢查這一行。稍后,將會看到 PHPEclipse 插件通過即時地給語法錯誤加下劃線并在保存文件時用紅色 “x” 標注語法錯誤,可在開發和調試過程中提供極大的幫助。

  先來看如何在 php.ini 文件中開啟錯誤報告并設置錯誤報告的級別。然后將學習如何在 Apache 的配置文件中覆蓋這些設置。

  PHP 的錯誤報告

  php.ini 文件中有許多配置設置。您應當已經設置好自己的 php.ini 文件并把它放在合適的目錄中,就像在 Linux 上安裝 PHP 和 Apache 2 的文檔說明中所示的那樣(請參閱 參考資料)。在調試 PHP 應用程序時,應當知道兩個配置變量。下面是這兩個變量及其默認值:

 display_errors = Off error_reporting = E_ALL 

  通過在 php.ini 文件中搜索它們,可以發現這兩個變量當前的默認值。display_errors 變量的目的很明顯 ―― 它告訴 PHP 是否顯示錯誤。默認值是 Off。但是,要讓開發過程更加輕松,請把這個值設為 On:

 display_errors = On 

  error_reporting 變量的默認值是 E_ALL。這個設置會顯示從不良編碼實踐到無害提示到出錯的所有信息。E_ALL 對于開發過程來說有點太細,因為它在屏幕上為一些小事(例如變量未初始化)也顯示提示,會搞糟瀏覽器的輸出。我只想看到錯誤和不良編碼實踐,但是不想看到無害的提示。所以,請用以下值代替 error_reporting 的默認值:

 error_reporting = E_ALL & ~E_NOTICE 

  重新啟動 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_flag  display_errors        on php_value error_reporting       2039 

  這會覆蓋在 php.ini 文件中為 display_errors 已經設置的標志,以及 error_reporting 的值。值 2039 代表 E_ALL & ~E_NOTICE。如果愿意采用 E_ALL,請把值設為 2047。同樣,還是要重啟 Apache。

  接下來,要在服務器上測試錯誤報告。
  測試錯誤報告

  如果啟動了錯誤報告,會節約許多時間。PHP 中的錯誤會指向代碼中的錯誤。請創建一個簡單的 PHP 文件 test.php,并像清單 1 所示一樣定義它。

清單 1. 一個生成錯誤的簡單 PHP
 <?php print("The next line generates an error.<br>"); printaline("PLEASE?"); print("This will not be displayed due to the above error."); ?> 

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

圖 1. 生成錯誤
按此在新窗口瀏覽圖片

  現在開啟了錯誤報告!接下來,用 print 語句幫助調試應用程序。

  介紹 print 語句

  因為應用程序中的功能性 bug 不會產生錯誤,所以在所有調試策略中,關于如何正確地放置和使用 print 或 die 語句來調試 PHP 應用程序的知識是一種很好的資產。可以用 print 語句在代碼中縮小對問題語句的定位,這些語句在語法上沒有錯誤,也不是 bug,但是從代碼的功能上看是 bug。這些是最難發現和調試的 bug,因為它們不會拋出錯誤。惟一知道的就是在瀏覽器上顯示的內容不是想要的內容,或者想要保存在數據庫中的內容根本沒有保存。

  假設正在處理通過 GET 請求發送過來的表單數據,想向瀏覽器顯示信息,但是出于某種原因,數據沒有正確地提交,或者不能正確地從 GET 請求中讀出。要調試這類問題,重要的是用 print() 或 die() 語句知道變量的值是什么。

  die() 語句會中止程序執行,并在 Web 瀏覽器上顯示文本。如果不想注釋掉代碼,而且只想顯示到出錯之前的信息和出錯信息,不想顯示后面的信息,那么 die() 語句特別有用。

  讓我們在 PHP 中用 print 語句來測試這個概念

  使用 print 語句進行調試

  在我作程序員的那些時候,當我在 Linux? 上開發應用程序時,沒有方便的 GUI 可以告訴我 bug 在哪,我迅速地發現我在程序中放的 print 語句越多,我在應用程序中把 bug 的范圍縮小到一行的機會越大。請創建另一個 PHP 文件 test2.php,并像清單 2 所示的那樣定義它。

清單 2. 顯示通過 GET 提交的所有變量
 <?php  $j = "";  print("Lets retrieve all the variables submitted to this ");  print("script via a GET request:<br>");  foreach($_GET as $key => $i){      print("$key=$j<br>");  }  if($_GET['Submit'] == "Send GET Request")      $j = "done!<br>"; ?> <form method="GET">      Name: <input name="name"><br>      Email: <input name="email" size="25"><br>      <input name="Submit" type="submit" value="Send GET Request"> </form> 

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

圖 2. test2.php 的輸出
按此在新窗口瀏覽圖片

  現在單擊 Send GET Request 按鈕,請注意只有 $_GET 請求的鍵顯示在瀏覽器上,而正確的值都沒顯示??梢栽谘h中放一個 print 語句,檢驗在 foreach 循環中每個元素中是否確實存在數據。請參閱清單 3。

清單 3. 用 print 語句驗證代碼的功能
 ...  foreach($_GET as $key => $i){      print("Correct data? " . $_GET[$key] . "<br>");      print("$key=$j<br>");  } ... 


  放進去的 print 語句是粗體。注意,現在已經知道在 Web 瀏覽器上顯示的 $key 值是正確的,但是由于某些原因,值沒有正確地顯示。請看新的輸出,如圖 3 所示。

圖 3. 修改后的 test2.php 的輸出
按此在新窗口瀏覽圖片

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

圖 4. 修正后的 test2.php 的輸出
按此在新窗口瀏覽圖片

  現在可以刪除或注釋掉剛才添加的 print 語句了,因為已經發現了代碼中的 bug。注意,這只是在調試應用程序時可能遇到的許多錯誤中的一個很小的子集。對于使用數據庫時可能遇到的問題,一個好的解決方案是輸出 SQL 語句,以確保執行的 SQL 就是想要執行的。

  現在要來看看如何使用 Eclipse IDE 和 PHPEclipse 插件及調試器擴展進一步在調試歷程中提供幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲黄页视频免费观看| 97在线日本国产| 成人福利免费观看| 国产精品久久久久77777| 久久久久99精品久久久久| 日韩av免费在线| 亚洲电影免费观看| 欧美成人小视频| 国产精品九九久久久久久久| 亚洲va欧美va在线观看| 久久久久久久久久久国产| 国产激情999| 2019中文字幕在线| 欧美性生交大片免费| 日韩精品在线观看视频| 中国日韩欧美久久久久久久久| 午夜精品久久久久久久99热浪潮| 国产精品高潮粉嫩av| 欧美色道久久88综合亚洲精品| 日韩大片免费观看视频播放| 色播久久人人爽人人爽人人片视av| 欧美日韩中文在线| 欧美另类xxx| 自拍偷拍免费精品| 欧美野外猛男的大粗鳮| 成人免费看吃奶视频网站| 亚洲国产精品中文| 国产精品96久久久久久又黄又硬| 国产精品成人av在线| 亚洲xxxx3d| 久久影视免费观看| 国产亚洲视频在线| 久久久精品网站| 一本色道久久综合狠狠躁篇怎么玩| 久久久久久亚洲精品不卡| 国产精品高潮呻吟久久av无限| 久久99久国产精品黄毛片入口| 亚洲欧美国产精品| 久久亚洲成人精品| 国产91精品久| 一本色道久久综合狠狠躁篇怎么玩| 国产成人综合av| 精品少妇v888av| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久天天躁狠狠躁夜夜av| 欧美视频国产精品| 日韩激情第一页| 久久亚洲成人精品| 97人洗澡人人免费公开视频碰碰碰| 91天堂在线视频| 国产亚洲精品久久久久久牛牛| 成人免费视频97| 一区二区三区黄色| 黑人与娇小精品av专区| 国产精品视频久久久久| 久久国产精品久久久久久| 日韩欧美在线字幕| 国产精品日韩久久久久| 欧美久久精品一级黑人c片| 久久精品美女视频网站| 欧美日韩高清在线观看| 国产一区二区激情| 亚洲成年人影院在线| 久久久久五月天| 国产精品夜色7777狼人| 人人爽久久涩噜噜噜网站| 永久免费看mv网站入口亚洲| 亚洲精品乱码久久久久久金桔影视| 国产91|九色| 不卡av在线网站| 国产精品18久久久久久麻辣| 亚洲性日韩精品一区二区| 青青草国产精品一区二区| 欧美日韩亚洲精品一区二区三区| 久久伊人精品一区二区三区| 日韩精品在线观| 亚洲男人天堂古典| 午夜精品在线视频| 成人黄色影片在线| 久久久久一本一区二区青青蜜月| 亚洲片在线观看| 久久成年人免费电影| 成人信息集中地欧美| 久久中文字幕国产| 不卡毛片在线看| 国产精品91免费在线| 国产精品丝袜白浆摸在线| 亚洲国产精品久久久久久| 久久亚洲精品毛片| 色999日韩欧美国产| 午夜精品蜜臀一区二区三区免费| 免费成人高清视频| 91极品女神在线| 精品偷拍各种wc美女嘘嘘| 久久精品亚洲一区| 国产精品入口免费视频一| 伊人精品在线观看| 亚洲国产高清高潮精品美女| 国产精品欧美亚洲777777| 国产精品久久9| 日韩电影大片中文字幕| 亚洲成人网在线观看| 久久久久久欧美| 日韩在线观看免费全集电视剧网站| 日av在线播放中文不卡| 18性欧美xxxⅹ性满足| 亚洲欧美另类自拍| 人九九综合九九宗合| 黄网站色欧美视频| 亚洲精品720p| 国产视频精品自拍| 国产主播精品在线| 91久久精品日日躁夜夜躁国产| 久久亚洲私人国产精品va| 欧美自拍大量在线观看| 2018日韩中文字幕| 日韩国产精品视频| 国产精品爽爽爽爽爽爽在线观看| 久久久电影免费观看完整版| 精品久久香蕉国产线看观看亚洲| 热久久美女精品天天吊色| 成人国产精品一区| 亚洲性无码av在线| 2020欧美日韩在线视频| 久久夜色精品国产| 国产一区二区三区在线视频| 亚洲欧美国产视频| 久久久久国产一区二区三区| 国产精品视频久久久| 亚洲一二三在线| 精品国偷自产在线视频| 欧美电影免费观看高清完整| 日本久久久久亚洲中字幕| 日韩欧美国产免费播放| 久久精品夜夜夜夜夜久久| 成人国产精品日本在线| 成人中文字幕在线观看| 91精品国产色综合久久不卡98| 高清亚洲成在人网站天堂| 国产精品中文字幕在线| 日韩电影中文字幕在线观看| 欧美一区亚洲一区| 在线亚洲国产精品网| 曰本色欧美视频在线| 超碰日本道色综合久久综合| 欧美日韩精品二区| 日韩精品久久久久久久玫瑰园| 亚洲男人的天堂在线播放| 亚洲激情在线视频| 亚洲理论在线a中文字幕| 精品人伦一区二区三区蜜桃免费| 91美女片黄在线观看游戏| 国产精品大片wwwwww| 日韩的一区二区| 136fldh精品导航福利| 91av在线国产| 日韩中文理论片| 午夜精品一区二区三区视频免费看| 欧美黄色片在线观看| 国产精品96久久久久久又黄又硬| 精品成人69xx.xyz| 欧美电影免费观看| 久久久久久久色| 亚洲精品之草原avav久久|