您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關使用ThinkPHP應該掌握哪些調試手段,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
使用ThinkPHP應該掌握的調試手段
經常看到有人問到findAll的返回數據類型是什么之類的問題,以及出錯了不知道什么原因的情況,其實還是沒有熟悉ThinkPHP內置的調試手段和方法,拋開IDE本身自帶的調試方式不說,如果你正在用或者打算用ThinkPHP開發的話,那么下面一些和調試相關的方法你是應該要了解和掌握的:
1、在項目配置文件里面打開調試模式DEBUG_MODE,這樣能夠讓你發現大部分的錯誤原因 。可能影響驗證碼的輸出。
2、如果不想使用調試模式,可以單獨開啟頁面Trace顯示。發現很多人不想使用調試模式的原因居然是因為有頁面Trace信息的輸出,其實這里面有一個誤區,以為調試模式就一定會有頁面Trace,但其實調試模式和頁面Trace沒有必然的關系,只是因為打開調試模式后,系統默認的調試配置文件會開啟頁面Trace顯示,所以你完全可以給項目單獨定義調試配置文件。
3、使用系統定義的dump函數,該方法同var_dump可以輸出任何類型的變量信息,而且更加有利于在瀏覽器里面查看,例如:
代碼如下:
$User = D("User"); $list = $User->findAll(); dump($list);
4、頁面Trace信息只能顯示當前頁面執行的sql語句,但無法查看ajax方式執行的后臺操作里面的sql語句,所以你還可以開啟sql日志記錄SQL_DEBUG_LOG 來記錄每一條執行的sql語句,并且可以查看到每條sql語句的執行時間 sql日志文件位于Logs目錄下面,會自動按日期來區分每天的sql日志。
5、另外一個是在執行某個數據操作后懷疑sql執行有錯誤的話,可以使用模型類的getLastSql方法來查看上次執行的sql語句,以便分析具體的錯誤原因。例如:
代碼如下:
$User = D("User"); $User->id = 3; $User->name = 'ThinkPHp'; $User->save(); echo $User->getLastSql(); // 輸出 update think_user set where id=3;
6、當需要調試某段代碼的運行時間的時候,可以使用系統提供的debug_start($label)和debug_end($label)方法,例如:
代碼如下:
debug_start('demo'); // 這里是你的代碼段....... debug_end('demo');
關于“使用ThinkPHP應該掌握哪些調試手段”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。