錯誤的級別
1. notice:提示2. warning:警告3. error:致命錯誤
- 1
- 2
- 3
- 4
- 5
注:notice和warning報錯后繼續執行,error報錯后停止
錯誤的提示方法
方法一:顯示在瀏覽器上
方法二:記錄在日志中執行
錯誤處理有關的配置(在php.ini中)
1. error_reporting = E_ALL:報告所有的錯誤
2. display_errors = On:將錯誤顯示在瀏覽器上
3. log_errors = On:將錯誤記錄在日志中
4. error_log=’地址’:錯誤日志保存的地址
- 1
- 2
- 3
- 4
項目開發的兩個模式:
開發模式:錯誤顯示在瀏覽器上,不要記錄在日志中
運行模式:錯誤不顯示在瀏覽器上,記錄是日志中
?
例題:
<?php
$debug=false; //true:開發模式 false:運行模式
ini_set('error_reporting',E_ALL); //所有的錯誤有報告
if($debug){ini_set('display_errors','on'); //錯誤顯示是瀏覽器上ini_set('log_errors','off'); //錯誤不顯示在日志中
}else{ini_set('display_errors','off');ini_set('log_errors','on');ini_set('error_log','./err.log'); //錯誤日志保存的地址
}//測試
echo $num;
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
自定義錯誤處理
通過trigger_error產生一個用戶級別的?error/warning/notice?信息
注意:用戶級別的錯誤的常量名中一定要帶有USER。
<?php
$age=100;
if($age>80){//trigger_error('年齡不能超過80歲'); //默認觸發了notice級別的錯誤//trigger_error('年齡不能超過80歲',E_USER_NOTICE); //觸發notice級別的錯誤//trigger_error('年齡不能超過80歲',E_USER_WARNING);trigger_error('年齡不能超過80歲',E_USER_ERROR); //錯誤用戶error錯誤
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
注冊錯誤處理函數,只要有錯誤就會自動調用錯誤處理函數:
定義錯誤處理函數:
function error() {echo '這是自定義錯誤處理';
}
set_error_handler('error'); //注冊錯誤處理函數,只要有錯誤就會自動的調用錯誤處理函數
echo $num;
- 1
- 2
- 3
- 4
- 5
自定義錯誤處理函數
/**
*自定義錯誤處理函數
*@param $errno int 錯誤類別
*@param $errstr string 錯誤信息
*@param $errfile string 文件地址
*@param $errline int 錯誤行號
*/
function error($errno,$errstr,$errfile,$errline) {switch($errno){case E_NOTICE:case E_USER_NOTICE:echo '記錄在日志中,上班后在處理<br>';break;case E_WARNING:case E_USER_WARNING: echo '給管理員發郵件<br>';break;case E_ERROR:case E_USER_ERROR:echo '給管理員打電話<br>';break;}echo "錯誤信息:{$errstr}<br>";echo "錯誤文件:{$errfile}<br>";echo "錯誤行號:{$errline}<br>";
}
set_error_handler('error');
echo $num;//運行結果
記錄在日志中,上班后在處理
錯誤信息:Undefined variable: num
錯誤文件:F:\wamp\www\4-demo.php
錯誤行號:50