ホームページ >php教程 >php手册 >用PHP即時捕捉PHP原始碼中的錯誤并發送email通知

用PHP即時捕捉PHP原始碼中的錯誤并發送email通知

WBOY
WBOYオリジナル
2016-05-30 16:59:451021ブラウズ

開發PHP的朋友都知道,其實最擔心的就是程序中出現一些異常或錯誤,這些狀況如果輸出到用戶的螢幕會把用戶給嚇壞,甚至為此丟了工作,如果不輸出到螢幕就得想辦法記錄到日誌中,但是似乎不是每個人都有查看錯誤日誌的習慣,爲了解決這個尷尬的問題,所以我寫了這段代碼,其用意就是當我們寫的php程式出錯的時候把錯誤內容捕捉出來然後發到我們的email內.
先看效果:

 

<span style="color: #008080;">Define</span>('SYS_DEBUG',<span style="color: #0000ff;">false</span><span style="color: #000000;">);
</span><span style="color: #0000ff;">IF</span><span style="color: #000000;">(SYS_DEBUG) {
</span><span style="color: #008080;">ini_set</span>('display_errors','on'<span style="color: #000000;">);
</span><span style="color: #008080;">Error_reporting</span>(<span style="color: #ff00ff;">E_ALL</span>);<span style="color: #008000;">//</span><span style="color: #008000;">上線后使用該設定Error_reporting(E_ERROR | E_WARNING | E_PARSE);</span>
}<span style="color: #0000ff;">Else</span><span style="color: #000000;">{
</span><span style="color: #008080;">ini_set</span>('display_errors','off'<span style="color: #000000;">);
</span><span style="color: #008080;">Error_reporting</span>(0<span style="color: #000000;">);
}

</span><span style="color: #008000;">//</span><span style="color: #008000;">錯誤捕捉</span>
<span style="color: #008080;">Register_shutdown_function</span>('Fun::Error'<span style="color: #000000;">);

</span><span style="color: #0000ff;">Class</span><span style="color: #000000;"> Fun{

</span><span style="color: #008000;">/*</span><span style="color: #008000;">*
通用出錯處理
参数:
要輸出的內容,是否終止執行程序
說明:
有傳值時該函式可以用來輸出自定義的錯誤內容
另外還可以配合Register_shutdown_function實現自動抓取錯誤內容,並將抓取的錯誤內容發送到Email內
Register_shutdown_function的機制是程序執行完畢或中途出錯時調用函數
如果是自動抓取錯誤時被調用,則會取得最後一次出錯的內容,如果發現沒有錯誤內容則跳出
返回:
內容會被直接輸出至螢幕或Email內
用法:
Fun::Error('錯誤內容');
Fun::Error('錯誤內容',False);
/*</span><span style="color: #008000;">*/</span>
<span style="color: #0000ff;">Public</span> <span style="color: #0000ff;">Static</span> <span style="color: #0000ff;">Function</span> Error(<span style="color: #800080;">$M</span>='',<span style="color: #800080;">$E</span>=<span style="color: #0000ff;">True</span><span style="color: #000000;">){
</span><span style="color: #800080;">$ErrTpl</span>='<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
{$M}
'; $M=Trim($M); IF($M!='') {//手工調用 $M=' 注意: '.$M; Echo Strtr($ErrTpl,Array('{$M}'=>$M));unSet($ErrTpl); IF($E===True) {Die();} Return ; }Else{//程式執行完畢自動抓取錯誤時調用 $M=error_get_last();//取得最後產生的錯誤 IF(!Is_array($M) Or Count($M)Unset($M);Return ;} IF(!File_Exists($M['file'])) {Unset($M);Return ;} //取得5行出錯關鍵代碼,如果取不到內容,說明出錯檔案不存在 $E=Array_slice(File($M['file']),($M['line']-4),5); IF(!Is_array($E)) {Unset($M,$E);Return ;} $E['M']=''; For($i=0;$i$i++) { $E[$i]=isSet($E[$i]) ? $E[$i] : ''; $E['M'].='  '; $E['M'].=($i==3) ? ''.(($M['line']-3)+($i+1)).'' : (($M['line']-3)+($i+1)); $E['M'].=': '.Htmlspecialchars($E[$i],ENT_QUOTES,'UTF-8').'
'; } $E=&$E['M']; $M='自動捕捉到有錯誤產生!

錯誤描述:
  '.$M['file'].'的第'.$M['line'].'行出現了類型為'.$M['type'].'的錯誤:
  '.$M['message'].'

關鍵代碼:
'.$E.'
'.self::now('Y-m-d H:i:s',time()).'
'; $M=Strtr($ErrTpl,Array('{$M}'=>$M));unSet($ErrTpl); $G=seft::getG('SYS','config'); IF(!self::Mail2($G['Spe'],'警告: '.$G['Tit'].' 出現 PHP 程式錯誤!',$M) And SYS_DEBUG===True){ throw new Exception('警告: '.$G['Tit'].' 出現 PHP 程式錯誤!

'.$M); } IF(SYS_DEBUG) {Echo $M;} unSet($E,$M,$G); Die(); } } /** 发送電郵 参数: 收件人,郵件標題(不可有換行符),郵件內容(行與行之間必須用\n分隔,每行不可超過70個字符) 說明: 調用PHP內置函式Mail發送電郵 返回: 返回布爾值 用法: $IsSend=Fun::Mail2($email,$tit,$msg); /**/ Public Static Function Mail2($to,$tit,$msg) { IF(Filter_var($to,FILTER_VALIDATE_EMAIL)==''){ throw new Exception('電郵地址錯誤!'); } $tit='=?UTF-8?B?'.Base64_Encode($tit).'?='; $msg = str_replace("\n.","\n..",$msg); //Windows如果在一行开头发现一个句号则会被删掉,要避免此问题将单个句号替换成两个句号 Return Mail($to,$tit,$msg,'From:'.seft::getG('config/SYS/Mal')."\n".'Content-Type:text/html;charset=utf-8'); } }

 

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。