我們知道產品的生產環境肯定是不給予顯示錯誤的,於是:
php.ini中將 display_errors = Off 改為display_errors = On
或者 ini_set('display_errors',0);
其次,我們知道php的錯誤層級是由error_reporting【error_reporting詳細教程】控制的,但是有很多人在生產環境關閉了錯誤資訊提示
error_reporting(0);
其實這種做法,我覺得不科學,在codeigniter架構就是這樣
| 代碼如下 |
複製代碼 |
if (defined('ENVIRONMENT')) { switch (ENVIRONMENT) { case 'development': error_reporting(E_ALL); break; case 'testing': case 'production': error_reporting(0); break; default: exit('The application environment is not set correctly.'); } } |
線上的錯誤資訊肯定是要記錄的,error_reporting(0)這樣會導致所有的錯誤資訊不會記錄,應該:error_reporting = E_ALL & ~E_NOTICE,只要display_errors = Off,錯誤資訊就不會再頁面上顯示,因為display_errors的優先順序別更高。
特別要注意的是:
如果php.ini中log_errors= On,據官方的說法,那麼必須指定error_log檔案,如果沒指定或者指定的檔案沒有許可權寫入,那麼照樣會輸出到正常的輸出渠道,那麼也就使得display_errors 這個指定的Off失效,錯誤資訊還是列印了出來。將log_errors = Off就行了。
總結下,在生產環境中不現實錯誤資訊還能記錄錯誤記錄檔:
| 代碼如下 |
複製代碼 |
<?php /** * 記錄生產環境錯誤記錄檔 * * @link http://www.111cn.net */ error_reporting(E_ALL); ini_set('display_errors',0); ini_set('log_errors',1); ini_set('error_log','E:\'.date('Y-m-d').'_phpddt.com.txt');
|