下面thinkphp框架教程欄目將給大家解析使用thinkphp應(yīng)該掌握的調(diào)試手段,希望對需要的朋友有所幫助!
解析使用thinkphp應(yīng)該掌握的調(diào)試手段
使用thinkphp應(yīng)該掌握的調(diào)試手段
經(jīng)??吹接腥藛柕絝indall的返回數(shù)據(jù)類型是什么之類的問題,以及出錯了不知道什么原因的情況,其實還是沒有熟悉thinkphp內(nèi)置的調(diào)試手段和方法,拋開ide本身自帶的調(diào)試方式不說,如果你正在用或者打算用thinkphp開發(fā)的話,那么下面一些和調(diào)試相關(guān)的方法你是應(yīng)該要了解和掌握的:
1、在項目配置文件里面打開調(diào)試模式debug_mode,這樣能夠讓你發(fā)現(xiàn)大部分的錯誤原因 ??赡苡绊戲炞C碼的輸出。
2、如果不想使用調(diào)試模式,可以單獨開啟頁面trace顯示。發(fā)現(xiàn)很多人不想使用調(diào)試模式的原因居然是因為有頁面trace信息的輸出,其實這里面有一個誤區(qū),以為調(diào)試模式就一定會有頁面trace,但其實調(diào)試模式和頁面trace沒有必然的關(guān)系,只是因為打開調(diào)試模式后,系統(tǒng)默認(rèn)的調(diào)試配置文件會開啟頁面trace顯示,所以你完全可以給項目單獨定義調(diào)試配置文件。
3、使用系統(tǒng)定義的dump函數(shù),該方法同var_dump可以輸出任何類型的變量信息,而且更加有利于在瀏覽器里面查看,例如:
代碼如下:
$user = d(\”user\”);$list = $user->findall();dump($list);
4、頁面trace信息只能顯示當(dāng)前頁面執(zhí)行的sql語句,但無法查看ajax方式執(zhí)行的后臺操作里面的sql語句,所以你還可以開啟sql日志記錄sql_debug_log 來記錄每一條執(zhí)行的sql語句,并且可以查看到每條sql語句的執(zhí)行時間 sql日志文件位于logs目錄下面,會自動按日期來區(qū)分每天的sql日志。
5、另外一個是在執(zhí)行某個數(shù)據(jù)操作后懷疑sql執(zhí)行有錯誤的話,可以使用模型類的getlastsql方法來查看上次執(zhí)行的sql語句,以便分析具體的錯誤原因。例如:
代碼如下:
$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)試某段代碼的運行時間的時候,可以使用系統(tǒng)提供的debug_start($label)和debug_end($label)方法,例如:
代碼如下:
debug_start(\’demo\’);// 這里是你的代碼段…….debug_end(\’demo\’);