溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

使用ThinkPHP應(yīng)該掌握的調(diào)試手段有哪些

發(fā)布時(shí)間:2021-10-12 14:55:40 來源:億速云 閱讀:97 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下使用ThinkPHP應(yīng)該掌握的調(diào)試手段有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

使用ThinkPHP應(yīng)該掌握的調(diào)試手段
經(jīng)??吹接腥藛柕絝indAll的返回?cái)?shù)據(jù)類型是什么之類的問題,以及出錯(cuò)了不知道什么原因的情況,其實(shí)還是沒有熟悉ThinkPHP內(nèi)置的調(diào)試手段和方法,拋開IDE本身自帶的調(diào)試方式不說,如果你正在用或者打算用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ú)開啟頁面Trace顯示。發(fā)現(xiàn)很多人不想使用調(diào)試模式的原因居然是因?yàn)橛许撁鎀race信息的輸出,其實(shí)這里面有一個(gè)誤區(qū),以為調(diào)試模式就一定會(huì)有頁面Trace,但其實(shí)調(diào)試模式和頁面Trace沒有必然的關(guān)系,只是因?yàn)榇蜷_調(diào)試模式后,系統(tǒng)默認(rèn)的調(diào)試配置文件會(huì)開啟頁面Trace顯示,所以你完全可以給項(xiàng)目單獨(dú)定義調(diào)試配置文件。

3、使用系統(tǒng)定義的dump函數(shù),該方法同var_dump可以輸出任何類型的變量信息,而且更加有利于在瀏覽器里面查看,例如:

復(fù)制代碼 代碼如下:


$User = D("User");
$list    = $User->findAll();
dump($list);


4、頁面Trace信息只能顯示當(dāng)前頁面執(zhí)行的sql語句,但無法查看ajax方式執(zhí)行的后臺(tái)操作里面的sql語句,所以你還可以開啟sql日志記錄SQL_DEBUG_LOG 來記錄每一條執(zhí)行的sql語句,并且可以查看到每條sql語句的執(zhí)行時(shí)間 sql日志文件位于Logs目錄下面,會(huì)自動(dòng)按日期來區(qū)分每天的sql日志。

5、另外一個(gè)是在執(zhí)行某個(gè)數(shù)據(jù)操作后懷疑sql執(zhí)行有錯(cuò)誤的話,可以使用模型類的getLastSql方法來查看上次執(zhí)行的sql語句,以便分析具體的錯(cuò)誤原因。例如:

復(fù)制代碼 代碼如下:


$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)方法,例如:

復(fù)制代碼 代碼如下:


debug_start('demo');
// 這里是你的代碼段.......
debug_end('demo');

以上是“使用ThinkPHP應(yīng)該掌握的調(diào)試手段有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI