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

首頁 > 語言 > PHP > 正文

PHP程序員的優(yōu)化調(diào)試技術(shù)和技巧

2024-09-04 11:50:09
字體:
供稿:網(wǎng)友
本文介紹調(diào)試 PHP 應(yīng)用程序的各種方法,包括在 Apache and PHP 中打開錯誤報告,以及通過在一個簡單的 PHP 腳本中放置策略性的 print 語句,找到更困難的 bug 的源頭。還會介紹用于 Eclipse 的 PHPEclipse 插件,這是一個靈活的開發(fā)環(huán)境,具有實時語法解析能力,還會介紹 PHPEclipse 的 DBG 調(diào)試器擴展。

  簡介

  有許多 PHP 調(diào)試技術(shù)可以在編碼的時候節(jié)約大量時間。一個有效卻很基本的調(diào)試技術(shù)就是打開錯誤報告。另一個略微高級一點的技術(shù)包括使用 print 語句,通過顯示在屏幕上實際出現(xiàn)的內(nèi)容,有助于精確地找出更難發(fā)現(xiàn)的 bug。PHPEclipse 是一個 Eclipse 插件,能夠強調(diào)常見的語法錯誤,可以與調(diào)試器結(jié)合起來用于設(shè)置斷點。

  設(shè)置

  要學(xué)習(xí)本文描述的概念,需要 PHP、Web 服務(wù)器和 Eclipse。調(diào)試器擴展支持的 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)試器擴展模塊。安裝它略有些麻煩。請仔細跟隨安裝調(diào)試器擴展的操作說明?,F(xiàn)在,先在 php.ini 文件中注釋掉那些要求裝入和配置 PHP 擴展的行。在需要使用調(diào)試器的時候,再取消注釋。

  請參閱 參考資料 獲得下載信息?,F(xiàn)在介紹出錯消息。

  出錯消息

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

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

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

  PHP 的錯誤報告

  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)知道兩個配置變量。下面是這兩個變量及其默認值:

 display_errors = Off error_reporting = E_ALL 

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

 display_errors = On 

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

 error_reporting = E_ALL & ~E_NOTICE 

  重新啟動 Apache,就全部設(shè)置好了。接下來,將學(xué)習(xí)如何在 Apache 上做同樣的事。

  服務(wù)器上的錯誤報告

  依賴于 Apache 正在做的工作,在 PHP 中打開錯誤報告可能沒法工作,因為在計算機上可能有多個 PHP 版本。有時很難區(qū)分 Apache 正在使用哪個 PHP 版本,因為 Apache 只能查看一個 php.ini 文件。不知道 Apache 正在使用哪個 php.ini 文件配置自己是一個安全問題。但是,有一種方法可以在 Apache 中配置 PHP 變量,從而保證設(shè)置了正確的出錯級別。

  而且,最好知道如何在服務(wù)器端設(shè)置這些配置變量,以否決或搶占 php.ini 文件,從而提供更高級別的安全性。

  在配置 Apache 時,應(yīng)該已經(jīng)接觸過 <apache2-install-dir>/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ù)器上測試錯誤報告。
  測試錯誤報告

  如果啟動了錯誤報告,會節(jié)約許多時間。PHP 中的錯誤會指向代碼中的錯誤。請創(chuàng)建一個簡單的 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 瀏覽器顯示它的內(nèi)容。但是第二個語句會生成錯誤并在 Web 頁面上顯示。這造成最后一個 print() 語句不起作用,如圖 1 所示。

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

  現(xiàn)在開啟了錯誤報告!接下來,用 print 語句幫助調(diào)試應(yīng)用程序。

  介紹 print 語句

  因為應(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,因為它們不會拋出錯誤。惟一知道的就是在瀏覽器上顯示的內(nèi)容不是想要的內(nèi)容,或者想要保存在數(shù)據(jù)庫中的內(nèi)容根本沒有保存。

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

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

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

  使用 print 語句進行調(diào)試

  在我作程序員的那些時候,當(dāng)我在 Linux? 上開發(fā)應(yīng)用程序時,沒有方便的 GUI 可以告訴我 bug 在哪,我迅速地發(fā)現(xiàn)我在程序中放的 print 語句越多,我在應(yīng)用程序中把 bug 的范圍縮小到一行的機會越大。請創(chuàng)建另一個 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> 

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

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

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

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


  放進去的 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 語句了,因為已經(jīng)發(fā)現(xiàn)了代碼中的 bug。注意,這只是在調(diào)試應(yīng)用程序時可能遇到的許多錯誤中的一個很小的子集。對于使用數(shù)據(jù)庫時可能遇到的問題,一個好的解決方案是輸出 SQL 語句,以確保執(zhí)行的 SQL 就是想要執(zhí)行的。

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
91老师国产黑色丝袜在线| 在线香蕉视频| 黄色美女网站在线观看| 春意影院午夜免费入口| 国产精品欧美综合亚洲| 在线观看成人av| 97久久伊人激情网| 欧美精品日韩一本| 成 人 黄 色 片 在线播放| 国产精品久久久久久久久粉嫩av| www.国产视频.com| 国产高清不卡无码视频| 欧美电影免费网站| 亚洲黄色网址| 精品91自产拍在线观看一区| 国产精品成人一区二区三区夜夜夜| 日韩大陆欧美高清视频区| h1515四虎成人| 亚洲日本一区二区三区在线观看| 日韩av影片在线观看| 欧美四级电影在线观看| 欧美精品影院| 大陆一级毛片免费观看| 国产午夜精品一区二区三区视频| 一级特黄特色的免费大片| 国产精品欧美久久| 精品美女国产在线| 精品久久99| 亚洲性生活视频在线观看| 免费网站黄在线观看| 日韩无码精品一区二区| 国产成人免费高清| 久久免费少妇高潮99精品| 成人激情诱惑| 久久这里只有精品6| 精品国产一区三区| 免费看黄视频网站| 国产高清视频免费| 成人午夜视频在线播放| 国产一区二区导航在线播放| 你懂的一区二区| 国产精品羞羞答答在线观看| 第四色中文综合网| 精品一区二区三区毛片| 欧美老年两性高潮| 狼人综合视频| 国产高清一区二区三区| 欧美丝袜丝交足nylons| 日韩精品av一区二区三区| 久久99久久99精品| 亚洲第一视频| 午夜影院网站| 色综合网色综合| 久久精品九九| av日韩在线免费| 91丝袜美腿高跟国产极品老师| 亚洲高清在线视频| 亚洲欧美精品suv| 久久99高清| 欧美一级免费| mm视频在线视频| 天天影视久久综合| 国产精品精品视频一区二区三区| 欧美成人a交片免费看| 91九色鹿精品国产综合久久香蕉| 精品久久免费| 51午夜精品视频| 天堂蜜桃一区二区三区| 欧美精品中文| 日韩免费看片| 国产福利a级| 中文字幕不卡在线| 黑吊大战白xxxxxx| 亚洲午夜国产一区99re久久| 麻豆视频一区二区| 日韩电影在线免费观看| 久久综合久久综合这里只有精品| freexxx性亚洲精品| 国产成人精品视频在线| 2019中文字幕在线观看| 久久久亚洲欧洲日产国码αv| 成人免费自拍视频| xxxx视频在线| 91短视频版在线观看www免费| 小说区图片区综合久久88| 激情综合五月网| 网站一区二区| 亚洲国产影院| 成人黄色av免费在线观看| 九九精品视频在线观看| 国产高潮免费视频| 日韩欧美精品在线观看| 免费毛片一区二区三区久久久| 香蕉人妻av久久久久天天| 免费在线播放第一区高清av| 日韩一区二区在线免费观看| 四虎永久免费在线| 我要色综合中文字幕| 午夜欧美不卡精品aaaaa| 国产精品国产成人国产三级| 日韩欧美四区| 91美女片黄在线观看| 久久久美女艺术照精彩视频福利播放| 国产丰满果冻videossex| 91美女视频在线| 午夜在线视频一区二区区别| 欧美日韩国产综合一区二区三区| 91九色在线视频| 操操操com| 一色屋色费精品视频在线看| 国产美女福利在线| 宅男噜噜噜66一区二区| 美女脱光内衣内裤视频久久网站| 久久久久久久久久av| 中文字幕在线第一页| 97精品国产一区二区三区| 国产乱叫456在线| 视频一区二区在线观看| 国产精品vvv| 国产亚av手机在线观看| xxxxxxxxx欧美| 日韩欧美在线观看强乱免费| www.xxxx国产| 91精品国产91久久久久麻豆 主演| 在线播放黄网| 热99在线视频| 欧美精品入口蜜桃| 欧美亚洲一级片| 蜜桃色一区二区三区| 亚洲国产成人porn| 亚洲一区二区三区久久| 国产视频1区2区3区| 欧美一区二区三区播放| 中文在线最新版天堂| 久久久久久一区二区三区四区别墅| 91精品蜜臀在线一区尤物| 国产99在线 | 亚洲| 欧美激情不卡| 欧美黑人疯狂性受xxxxx野外| 一级黄色a毛片| 在线观看国产视频一二三| 香蕉视频在线看| 久久久久亚洲| 欧美午夜片欧美片在线观看| 99精品视频精品精品视频| 亚洲国产综合人成综合网站| 日韩一区二区a片免费观看| 欧美成人免费视频a| 国产欧美日韩视频一区二区三区| 欧美性色黄大片手机版| 男人通一通女人的下水道| 老司机性视频| 国产精品亚洲视频在线观看| 综合天堂久久久久久久| 亚洲人成影院在线| 91麻豆桃色免费看| 国产精品高颜值在线观看| 91午夜视频| 在线免费黄色毛片| 伊人中文字幕在线| 国产激情一区二区三区四区| 国产精品香蕉一区二区三区| 国产玖玖精品视频| 久久99精品久久久久久野外| 性欧美性free| 一本久道中文无码字幕av| 成人欧美一区二区三区视频xxx| 99亚洲男女激情在线观看| 成人免费一区二区三区视频网站| 国产免费成人| 亚洲小少妇裸体bbw| 激情一区二区| 国产夫妻自拍一区| 亚洲一区精品在线观看| 欧美野外猛男的大粗鳮| 国产精品久久久久免费a∨大胸| 综合久久伊人| 欧美三级一区二区| 亚洲第一二三四区| 男女人搞j网站| 成a人片亚洲日本久久| 亚洲视频 中文字幕| 一本色道综合亚洲| 四虎影视精品成人| 暖暖影院日本高清...免费| 中文字幕精品一区二区精品| 少妇精品无码一区二区免费视频| 国产主播一区| 在线观看亚洲精品| 亚洲精品**中文毛片| 成人ssswww在线播放| 99精品国产99久久久久久白柏| 国产经典三级在线| 国产男女猛烈无遮挡在线喷水| 粉嫩欧美一区二区三区| 亚洲精品久久久一区二区三区| 久久久久久久免费视频| 国产成人无码精品久久二区三| 日本精品一区二区三区在线播放视频| 亚洲黄色大片| 嫩草影院网站在线| 国产激情一区二区三区| 大地资源中文在线观看免费版| 性生生活大片免费看视频| 欧美色图欧美色图| 国产欧美日韩免费| 欧美日韩在线亚洲一区蜜芽| 国产精品探花在线播放| 中文在线观看免费| 精品亚洲美女网站| 久国产精品韩国三级视频| 日韩欧美999| 国产又粗又黄又爽| 麻豆国产va免费精品高清在线| 欧美人交a欧美精品| 精品人妻少妇嫩草av无码| 熟女少妇一区二区三区| 91a在线视频| 亚洲成人在线视频播放| 久久婷五月综合| 日韩黄色大片网站| 国产高清av| 国产日韩影视精品| 久久99精品久久久久久久久久久久| 国产精品久久久久7777婷婷| 欧美老年两性高潮| 成人美女免费网站视频| 在线观看一区欧美| 老司机免费视频一区二区| 天天影视色综合| 中文字幕人妻熟女人妻洋洋| 日韩欧美国产三级电影视频| 亚洲精品一区二区在线看| 亚洲精品少妇网址| 99视频国产精品免费观看| 成人福利电影| 天天综合色天天综合色hd| 亚洲激情视频网| 亚洲黄色在线视频| 国产精品yjizz视频网一二区| 国产欧美啪啪| 欧亚乱熟女一区二区在线| 国产精品久久久久久久久久10秀| 羞羞视频在线观看一区二区| 大肉大捧一进一出好爽动态图| xxav国产精品美女主播| 麻豆免费版在线观看| 亚洲视频网站在线观看| 一区二区三区四区高清精品免费观看| 欧美激情在线狂野欧美精品| 好吊一区二区三区视频| 天天摸夜夜操| 91久久精品日日躁夜夜躁欧美| 偷偷操不一样的久久| 日韩三级视频中文字幕| 国产精品yjizz| 综合久久一区二区三区| 欧美女子与性| 91麻豆成人精品国产| 日本成人黄色网址| 夜夜狠狠擅视频| avtt天堂资源网站| 国产精品69久久久久孕妇欧美| 一级性生活视频| 99热国内精品永久免费观看| 日韩中文字幕免费视频| 天堂v视频永久在线播放| 欧美精品一区二区久久| 久久久综合九色合综国产精品| 最近2018年手机中文在线| 欧美日韩国产小视频在线观看| 97免费视频在线播放| 国产精品久久久久久亚洲av| 欧美激情一区不卡| 91高清免费视频| 婷婷综合视频| 久久黄色免费网站| 国产欧美黑人| 亚洲午夜久久久久久久久久久| 国产精品一区2区3区| 国产精品视频第一区二区三区| 夜夜嗨av一区二区三区| 欧美专区一区二区三区| 欧美极品美女视频网站在线观看免费| 日韩欧美中文字幕公布| 无码人妻精品一区二区三应用大全| 日本高清视频免费看| 咪咪色在线视频| 色欲狠狠躁天天躁无码中文字幕| 欧美日韩亚洲一区二区三区| 亚洲有吗中文字幕| 丝袜在线观看| 欧美伊人久久久久久午夜久久久久| 麻豆国产精品| 国产美女自拍视频| 粉嫩av一区| 性色a∨人人爽网站| 欧美精品videossex性护士| 国产 日韩 欧美大片| 国产麻豆一区二区三区精品| 成人短视频在线看| 日韩在线观看视频一区二区三区| 欧美激情性做爰免费视频| 亚洲理论在线a中文字幕| 热re91久久精品国99热蜜臀| 中文字幕精品综合| 性视频一区二区三区| 日本一区二区久久| 91精品又粗又猛又爽| 日韩一区二区三区不卡| 亚洲欧洲美洲av| 免费日本黄色| 久久精品水蜜桃av综合天堂| 欧美一级久久久久久久大片| 精品成人一区二区三区四区| 精品极品三级久久久久| 国产精品成人免费一区二区视频| 国严精品久久久久久亚洲影视| 日韩亚洲欧美中文三级| av电影在线地址| 国产精品久久久久久久久久免费| 蜜桃精品wwwmitaows| 97精品一区二区| 亚洲国产精品久久久男人的天堂| 日韩精品在线观看一区二区| 亚洲精品v欧美精品v日韩精品| 一区二区三区四区视频免费观看| 少妇久久久久久被弄高潮|