PHP線上錯誤記錄檔控制(error_reporting和display_errors)

來源:互聯網
上載者:User

我們知道產品的生產環境肯定是不給予顯示錯誤的,於是:
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');

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.