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

來源:互聯網
上載者:User
經常看到有人問到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關閉緩衝的方法

http://www.bkjia.com/PHPjc/764142.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/764142.htmlTechArticle經常看到有人問到findAll的返回資料類型是什麼之類的問題,以及出錯了不知道什麼原因的情況,其實還是沒有熟悉ThinkPHP內建的調試手段和...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.