程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 使用ThinkPHP必須掌握的調試方法

使用ThinkPHP必須掌握的調試方法

編輯:關於PHP編程

經常看到有人問到findAll的返回數據類型是什麼之類的問題,以及出錯了不知道什麼原因的情況,其實還是沒有熟悉ThinkPHP內置的調試手段和方法,拋開IDE本身自帶的調試方式不說,如果你正在用或者打算用ThinkPHP開發的話,那麼下面一些和調試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 name='ThinkPHP' where id=3;

6、當需要調試某段代碼的運行時間的時候,可以使用系統提供的debug_start($label)和debug_end($label)方法,例如:

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

您可能感興趣的文章

  • thinkphp模板中判斷volist循環的最後一條記錄
  • thinkphp頁面跳轉(successerror)如何設置跳轉等待時間
  • thinkphp打印最後一條sql語句
  • thinkphp自動驗證與自動填充無效的解決辦法
  • thinkphp 的 Action 控制器中的系統常量總結
  • ThinkPHP中的查詢技巧總結
  • ThinkPHP內置模板引擎的使用方法總結
  • thinkphp關閉緩存的方法

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved