下面thinkphp框架教程欄目將給大家解析使用thinkphp應(yīng)該掌握的調(diào)試手段,希望對(duì)需要的朋友有所幫助!
解析使用ThinkPHP應(yīng)該掌握的調(diào)試手段
使用ThinkPHP應(yīng)該掌握的調(diào)試手段
經(jīng)常看到有人問(wèn)到findAll的返回?cái)?shù)據(jù)類型是什么之類的問(wèn)題,以及出錯(cuò)了不知道什么原因的情況,其實(shí)還是沒(méi)有熟悉ThinkPHP內(nèi)置的調(diào)試手段和方法,拋開IDE本身自帶的調(diào)試方式不說(shuō),如果你正在用或者打算用ThinkPHP開發(fā)的話,那么下面一些和調(diào)試相關(guān)的方法你是應(yīng)該要了解和掌握的:?
1、在項(xiàng)目配置文件里面打開調(diào)試模式DEBUG_MODE,這樣能夠讓你發(fā)現(xiàn)大部分的錯(cuò)誤原因 。可能影響驗(yàn)證碼的輸出。
立即學(xué)習(xí)“PHP免費(fèi)學(xué)習(xí)筆記(深入)”;
2、如果不想使用調(diào)試模式,可以單獨(dú)開啟頁(yè)面Trace顯示。發(fā)現(xiàn)很多人不想使用調(diào)試模式的原因居然是因?yàn)橛许?yè)面Trace信息的輸出,其實(shí)這里面有一個(gè)誤區(qū),以為調(diào)試模式就一定會(huì)有頁(yè)面Trace,但其實(shí)調(diào)試模式和頁(yè)面Trace沒(méi)有必然的關(guān)系,只是因?yàn)榇蜷_調(diào)試模式后,系統(tǒng)默認(rèn)的調(diào)試配置文件會(huì)開啟頁(yè)面Trace顯示,所以你完全可以給項(xiàng)目單獨(dú)定義調(diào)試配置文件。?
3、使用系統(tǒng)定義的dump函數(shù),該方法同var_dump可以輸出任何類型的變量信息,而且更加有利于在瀏覽器里面查看,例如:
代碼如下:
$User?=?D("User"); $list?=?$User->findAll(); dump($list);
4、頁(yè)面Trace信息只能顯示當(dāng)前頁(yè)面執(zhí)行的sql語(yǔ)句,但無(wú)法查看ajax方式執(zhí)行的后臺(tái)操作里面的sql語(yǔ)句,所以你還可以開啟sql日志記錄SQL_DEBUG_LOG 來(lái)記錄每一條執(zhí)行的sql語(yǔ)句,并且可以查看到每條sql語(yǔ)句的執(zhí)行時(shí)間 sql日志文件位于Logs目錄下面,會(huì)自動(dòng)按日期來(lái)區(qū)分每天的sql日志。?
5、另外一個(gè)是在執(zhí)行某個(gè)數(shù)據(jù)操作后懷疑sql執(zhí)行有錯(cuò)誤的話,可以使用模型類的getLastSql方法來(lái)查看上次執(zhí)行的sql語(yǔ)句,以便分析具體的錯(cuò)誤原因。例如:
代碼如下:
$User?=?D("User"); $User->id?=?3; $User->name?=?'ThinkPHp'; $User->save(); echo?$User->getLastSql(); //?輸出?update?think_user?set?where?id=3;
6、當(dāng)需要調(diào)試某段代碼的運(yùn)行時(shí)間的時(shí)候,可以使用系統(tǒng)提供的debug_start($label)和debug_end($label)方法,例如:
代碼如下:
debug_start('demo'); //?這里是你的代碼段....... debug_end('demo');