解析使用ThinkPHP應(yīng)該掌握的調(diào)試手段
使用ThinkPHP應(yīng)該掌握的調(diào)試手段
經(jīng)常看到有人問(wèn)到findAll的返回?cái)?shù)據(jù)類型是什么之類的問(wèn)題,以及出錯(cuò)了不知道什么原因的情況,其實(shí)還是沒有熟悉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)證碼的輸出。
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沒有必然的關(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 name='ThinkPHP' 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');
- thinkPHP框架中執(zhí)行原生SQL語(yǔ)句的方法
- thinkphp中多表查詢中防止數(shù)據(jù)重復(fù)的sql語(yǔ)句(必看)
- 解決ThinkPHP關(guān)閉調(diào)試模式時(shí)報(bào)錯(cuò)的問(wèn)題匯總
- ThinkPHP調(diào)試模式與日志記錄概述
- thinkphp中常用的系統(tǒng)常量和系統(tǒng)變量
- ThinkPHP模版引擎之變量輸出詳解
- thinkPHP5.0框架環(huán)境變量配置方法
- 解析thinkphp import 文件內(nèi)容變量失效的問(wèn)題
- thinkPHP控制器變量在模板中的顯示方法示例
- ThinkPHP框架獲取最后一次執(zhí)行SQL語(yǔ)句及變量調(diào)試簡(jiǎn)單操作示例
相關(guān)文章
Windows上PHP安裝redis擴(kuò)展和igbinary擴(kuò)展
php擴(kuò)展就是php核心并不支持的功能,通過(guò)安裝擴(kuò)展增加PHP的功能,在Windows上有兩種加載PHP擴(kuò)展的方式:把擴(kuò)展編譯進(jìn)?PHP,或者加載?DLL,加載預(yù)編譯的擴(kuò)展是更簡(jiǎn)單更被推薦的方式,要加載某擴(kuò)展,需要在系統(tǒng)中有其相對(duì)應(yīng)的“.dll”文件2023-10-10
解析PHP強(qiáng)制轉(zhuǎn)換類型及遠(yuǎn)程管理插件的安全隱患
這篇文章主要介紹了PHP強(qiáng)制轉(zhuǎn)換類型及遠(yuǎn)程管理插件的安全隱患,需要的朋友可以參考下2014-06-06
php啟動(dòng)時(shí)候提示PHP startup的解決方法
配置好php環(huán)境后,每次開機(jī)都有警告提示說(shuō) PHP startup,解決這個(gè)問(wèn)題很簡(jiǎn)單只需要在php.ini 文件中修改 extension_dir配置就行2013-05-05
php5 圖片驗(yàn)證碼實(shí)現(xiàn)代碼
php5 圖片驗(yàn)證碼,需要的朋友可以參考下。2009-12-12
簡(jiǎn)單實(shí)用的PHP防注入類實(shí)例
這篇文章主要介紹了簡(jiǎn)單實(shí)用的PHP防注入類實(shí)例,以兩個(gè)簡(jiǎn)單的防注入類為例介紹了PHP防注入的原理與技巧,對(duì)網(wǎng)站安全建設(shè)來(lái)說(shuō)非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-12-12
PHP ADODB生成HTML表格函數(shù)rs2html功能【附錯(cuò)誤處理函數(shù)用法】
這篇文章主要介紹了PHP ADODB生成HTML表格函數(shù)rs2html功能,結(jié)合實(shí)例形式分析了php使用ADODB類使用函數(shù)rs2html輸出結(jié)果集生成HTML表格相關(guān)操作技巧,并附錯(cuò)誤處理函數(shù)errorMsg用法,需要的朋友可以參考下2018-05-05

